(89)Wangdao.com第二十二天_JavaScript 属性
属性
属性本身是一个对象(Attr 对象)
- Element.attributes
- 返回一个类似数组的动态对象,成员是该元素标签的所有属性节点对象
- 属性的实时变化都会反映在这个节点对象上。
- 其他类型的节点对象,虽然也有 attributes 属性,但返回的都是 null,因此可以把这个属性视为元素对象独有的
- 取出每个属性节点对象(不是取属性值)
- 属性节点对象有 name 和 value 属性,对应该属性的属性名和属性值,等同于 nodeName 属性和 nodeValue 属性
// <div id="result" bgcolor="yellow">孙悟空</div> var ele = document.getElementById("result");
ele.innerHTML = ( ele.attributes[0].name+"----"+
ele.attributes[0].value+"<br />"+
ele.attributes[1].name+"----"+
ele.attributes[1].value);
- 属性节点对象有 name 和 value 属性,对应该属性的属性名和属性值,等同于 nodeName 属性和 nodeValue 属性
- 元素的标准属性
- 有些 HTML 属性名是 JavaScript 的保留字,
- 在JavaScript 中使用这些属性时,必须改名
- for 属性在使用时为 ele.htmlFor
- class 属性在使用时为 ele.className
- 属性操作的标准方法
适用所有属性
只会返回字符串
只接受标准名称,即 class 就是 "class",for 属性也可以直接使用
- Element.getAttribute()
- 返回一个数组,成员是当前元素的所有属性的名字
- 遍历某个节点的所有属性
- 方法1
var ele = document.getElementById("result");
var attrs = ele.attributes; ele.innerHTML += "<br />";
var i = 0;
for(i=0; i<attrs.length; i++){
ele.innerHTML += attrs[i].name+"----"+attrs[i].value+"<br />";
}
- 方法2
var mydiv = document.getElementById('mydiv'); mydiv.getAttributeNames().forEach(function (key) {
var value = mydiv.getAttribute(key);
console.log(key, value);
})
- 方法1
- Element.getAttribute()
- Element.setAttribute()
- 为当前元素节点新增属性
- 如果同名属性已存在,则相当于编辑已存在的属性
- 没有返回值
- Element.setAttribute()
- Element.hasAttribute()
- 当前元素节点是否包含指定属性
- Element.hasAttribute()
- Element.hasAttributes()
- 只要有一个属性,就返回 true
- Element.hasAttributes()
- Element.removeAttribute()
- 移除指定属性
- 没有返回值
- Element.removeAttribute()
- 标准提供的 data-xxx 属性 自定义属性
- 元素节点对象的 dataset 属性
- 通过 ele.dataset.foo 读写 data-foo 属性
// <div id="mydiv" data-foo="bar"> var n = document.getElementById('mydiv');
n.dataset.foo; // 返回 bar
n.dataset.foo = 'kjf';
- 通过 ele.dataset.foo 读写 data-foo 属性
- 元素节点对象的 dataset 属性
- 删除一个 data-* 属性,可以直接使用 delete 命令
var ele = document.getElementById("myDiv");
delete ele.dataset.foo;
- 删除一个 data-* 属性,可以直接使用 delete 命令
- data-属性名 命名有限制
- 只能包含字母、数字、连词线(-)、点(.)、冒号(:)和下划线(_)
- 属性名不应该使用 A 到 Z 的大写字母
- 比如不能有 data-helloWorld 这样的属性名,而要写成 data-hello-world
- data-属性名 命名有限制
- data-属性名 使用要注意
- 连词线后面如果跟着一个小写字母,那么连词线会被移除,该小写字母转为大写字母,其他字符不变
- 反过来,dataset 的键名转成属性名时,所有大写字母都会被转成连词线+该字母的小写形式,其他字符不变。
- 比如,dataset.helloWorld 会转成 data-hello-world
- data-属性名 使用要注意
(89)Wangdao.com第二十二天_JavaScript 属性的更多相关文章
- (89)Wangdao.com第二十二天_JavaScript DocumentFragment 节点
DocumentFragment 节点 代表一个文档的片段,本身就是一个完整的 DOM 树形结构. 它没有父节点,.parentNode 返回 null 可以插入任意数量的子节点. 不属于当前文档,操 ...
- (73)Wangdao.com第十二天_JavaScript consol 对象与控制台
consol 对象 console对象是 JavaScript 的原生对象 它有点像 Unix 系统的标准输出stdout和标准错误stderr, 可以输出各种信息到控制台,并且还提供了很多有用的辅助 ...
- (72)Wangdao.com第十二天_JavaScript 错误处理机制
1. Error 实例对象 JavaScript 解析或运行时,一旦发生错误,引擎就会抛出一个错误对象. JavaScript 原生提供Error构造函数,所有抛出的错误都是这个构造函数的实例. va ...
- javaSE第二十二天
第二十二天 312 1:登录注册IO版本案例(掌握) 312 2:数据操作流(操作基本类型数据的流)(理解) 313 (1)定义: 313 (2)流对象名称 313 (3 ...
- Python第二十二天 stat模块 os.chmod方法 os.stat方法 pwd grp模块
Python第二十二天 stat模块 os.chmod方法 os.stat方法 pwd grp模块 stat模块描述了os.stat(filename)返回的文件属性列表中各值的意义,根据 ...
- 孤荷凌寒自学python第二十二天python类的继承
孤荷凌寒自学python第二十二天python类的继承 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) python中定义的类可以继承自其它类,所谓继承的概念,我的理解 是,就是一个类B继承自 ...
- (90)Wangdao.com第二十三天_JavaScript CSS 操作
CSS 操作 通过 JavaScript 操作 CSS HTML 元素的 style 属性 <div style="background-color:red; border:1px s ...
- 我和linux的第二十二天
这几天学校的事情比较多,空闲时间也有,但没有利用起来.前些天听国学课,发觉自己心性还是不很成熟,以前自觉遇到君子应用君子的方法相处,遇到小人用小人的方法对待,老师一句话,疏清了自己.当我们用小人的方法 ...
- JQuery --- 第二期 (jQuery属性操作)
个人学习笔记 1.JQuery的内容选择器 <!DOCTYPE html> <html lang="en"> <head> <meta c ...
随机推荐
- django - 总结 - 中间件
中间件顾名思义,是介于request与response处理之间的一道处理过程,相对比较轻量级,并且在全局上改变django的输入与输出.因为改变的是全局,所以需要谨慎实用,用不好会影响到性能. MID ...
- QGE 在齐次 Besov 空间中的准则
在 [Zhang, Zujin. On the blow-up criterion for the quasi-geostrophic equations in homogeneous Besov s ...
- [高中作文赏析]妈妈, 我心中的"灯"
- [物理学与PDEs]第2章习题11 Lagrange 形式的一维理想流体力学方程组在强间断线上的间断连接条件
对由第 10 题给出的 Lagrange 形式的一维理想流体力学方程组, 给出解在强间断线上应满足的间断连接条件 (假设体积力 $F\equiv 0$). 解答: $$\beex \bea \sez{ ...
- [物理学与PDEs]第1章习题6 无限长载流直线的磁场
试计算电流强度为 $I$ 的无限长的直导线所产生的磁场的磁感强度. 解答: 设 $P$ 到直线的距离为 $r$, 垂足为 $P_0$, 则 ${\bf B}(P)$ 的方向为 ${\bf I}\tim ...
- MySQL的一些基本命令笔记(4)
delete 语句嵌套子查询: delete from 表名1 where 列名 操作符 (select 列名 from 表名2 where 条件); 示例: delete from customer ...
- 四十四、Linux 线程——线程同步之死锁以及线程和信号
44.1 死锁 死锁: 两个线程试图同时占有两个资源,并按不同的次序锁定相应的共享资源 解决方式: 按相同的次序锁定相应的共享资源 使用函数 pthread_mutex_trylock(),它是函数 ...
- 用juery的ajax方法调用aspx.cs页面中的webmethod方法
首先在 aspx.cs文件里建一个公开的静态方法,然后加上WebMethod属性. 如: [WebMethod] public static string GetUserName() { //.... ...
- Centos7 安装 jdk 1.8
Centos7 安装 jdk 1.8 1.下载安装包 链接: https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloa ...
- Choreographer解析
Choreographer_舞蹈编导 为什么叫舞蹈编导,因为舞蹈是由节奏的,节奏是每个点位动作的快慢控制,跳舞时节奏很重要,编舞者控制节奏.视图刷新也是如此,不是说你想刷就能刷,一切要按照底层信号要求 ...