当前位置: 首页 > news >正文

JS DOM、点击事件

JS DOM

加载事件onload

js代码执行的时候,需要html&css的支持
onload在页面加载完之后执行
dom:用JS对html标签进行增删改查

元素节点获取

var name = document.getElementById("userName");
var inputs = document.getElementsByTagName(''input);

文本节点获取

需要借助div元素节点在获得其内部的文本节点。

<div>hello<div>
var dvnode = document.getElementsByTagName('div')[0];
divnode.firstChild; //(或者调用lastChild)获得元素div内部的第一个子节点对象,而不是自己这个节点

兄弟节点

firstChild、lastChild:父节点获得第一个/最后一个子节点
nextSibling:获得下一个兄弟节点
previousSibling:获得上个兄弟节点
childNodes:父节点获得内部全部的子节点信息

<script>
window.onload = function() {var ull = document.getElementsByTagName('ul')[0];console.log(ull.childNodes);console.log(ull.firstChild);console.log(ull.firstChild.nextSibling);console.log(ull.lastChild);console,log(ull.lastChild.previousSibling);
}
</script>

父节点

节点名.parentNode

console.log(blue);
console.log(blue.parentNode);

属性值操作

1. 获取属性值

itnode.属性名; //只能操作五c规定的属性值
itnode.getAttribute(属性名); //规定的和自定义的都可以获取

2. 设置属性值

itnode.属性名 = 值; //只能操w3c规定的属性
itnode.setAttribute(名称,值); //规定的和自定义的都可以设置

console.log(baidu.className); //className是class的一个别名,不可以直接访问class属性

Field、Attribute、Property

节点创建和追加

1. 创建

元素节点:document.createElement(tag标签名);
文本节点:document.createTextNode(文本内容);
属性设置:node.setAttribute(名称,值);

2. 追加

父节点.appendChild(子节点);
父节点.insertBefore(newnode,oldnode); //newnode放到oldnode的前边
父节点.replaceChild(newnode,oldnode); //newnode替换到oldnode节点

节点删除

父节点.removeChild(子节点);

知道子节点的,需要通过子节点找到父节点,然后再删除子节点:
green.parentNode.removeChild(green);

点击事件

通过鼠标、键盘对页面所做的动作就是事件。事件一旦发生需要有事件处理,该处理成为“事件驱动”,事件驱动通常由函数担任

onclick、onmouseover、onmouseout、onkeyup、onkeydown、onblur、onfocus、onsubmit

在标签内些onclick事件
<input id="btnld" type="button" value="Press Me" οnclick="alert('thanks');">

在JS写οnclick=function(){}函数
var btn = document.getElementById('btnld');
btn.onclick = function() {
    alert('thanks');
}

http://www.lryc.cn/news/427803.html

相关文章:

  • 长短期记忆网络(LSTM)预测模型及其Python和MATLAB实现
  • C语言——操作符详解
  • 【Linux】内核全量函数添加日志打印摸索
  • 24/8/17算法笔记 CQL算法离线学习
  • C++第十一弹 -- STL之List的剖析与使用
  • 物流快递外卖管理平台系统-计算机毕设Java|springboot实战项目
  • 开源BaaS 平台介绍
  • 分享一个基于python爬虫的“今日头条”新闻数据分析可视化系统(源码、调试、LW、开题、PPT)
  • QT自定义信号槽
  • one-shot 序列图像红外小目标分割
  • JavaScript 单线程防阻塞的原理
  • Shell脚本发送邮件的详细步骤与配置方法?
  • 如何把Phalcon 集成到PhpStorm里面
  • python从入门到精通:循环语句
  • Codeforces Round 965 (Div. 2)
  • Win10下载安装Mysql服务
  • MVVM(Model-View-ViewModel)架构模式
  • C#MVC返回DataTable到前端展示。
  • HttpUtils工具类(二)Apache HttpClient 5 使用详细教程
  • Vue3.0生命周期钩子(包含:Vue 2.0 和 Vue 3.0)
  • 遥感之常用各种指数总结大全
  • 【C++】C++11新增特性
  • 【LeetCode每日一题】——662.二叉树最大宽度
  • 第二十三节、血量更新逻辑的实现
  • Spring Authorization Server 认证服务器搭建
  • 秋招突击——8/15——知识补充——垃圾回收机制
  • 【iOS】UITableViewCell的重用问题解决方法
  • 开发一个微信小程序商城需要哪些技术栈
  • 望繁信科技荣膺上海市浦东新区博士后创新实践基地称号
  • Nginx--代理与负载均衡(扩展nginx配置7层协议及4层协议方法、会话保持)