在jQuery的att
r与prop
提到过在IE9之前版本中如果使用property
不当会造成内存泄露问题,而且关于Attribute
和Property
的区别也让人十分头痛,在HTML5中添加了data-*
的方式来自定义属性,所谓data-*
实际上上就是data-
前缀加上自定义的属性名,使用这样的结构可以进行数据存放。使用data-*
可以解决自定义属性混乱无管理的现状。
1. 读写方式
data-*
有两种设置方式,可以直接在HTML元素标签
上书写:
其中的data-age
就是一种自定义属性,当然我们也可以通过JavaScript来对其进行操作,HTML5中元素都会有一个dataset
的属性,这是一个DOMStringMap
类型的键值对集合:
这样就为div
添加了一个data-my
的自定义属性,使用JavaScript操作dataset
有两个需要注意的地方:
- 1. 我们在添加或读取属性的时候需要去掉前缀
data-*
,像上面的例子我们没有使用test.dataset.data-my = 'Byron';
的形式。 - 2. 如果属性名称中还包含连字符(
-
),需要转成驼峰命名方式,但如果在CSS中使用选择器,我们需要使用连字符格式。
为刚才代码追加写内容:
这样我们通过JavaScript设置了data-birth-date自定义属性,在CSS样式表为div添加了一些样式,看看效果
读取的时候也是通过dataset
对象,使用”.
”来获取属性,同样需要去掉data-
前缀,连字符需要转化为驼峰命名
2. getAttribute/setAttribute
有些同学可能会问这和getAttribute
/setAttribute
除了命名有什么区别吗,我们来看一下:
这样我们可以看出,两者都把属性设置到了attribute上
(废话,要不人家能叫自定义属性),也就是说getAttribute
/setAttribute
可以操作所有的dataset
内容,dataset
内容只是attribute
的一个子集,特殊就特殊在命名上了,但是dataset
内只有带有data-
前缀的属性(没有age=25
那个)。
那么为什么我们还要用data-*
呢,一个最大的好处是我们可以把所有自定义属性在dataset
对象中统一管理,遍历啊神马的都哦很方便,而不至于零零散散了,所以用用还是不错的。
3. 浏览器兼容性
比较不好的消息就是data-*
的浏览器兼容性情况十分不乐观。
- Internet Explorer 11+
- Chrome 8+
- Firefox 6.0+
- Opera 11.10+
- Safari 6+
其中IE11+简直就是亮瞎小伙伴的眼,看来要想全面使用此属性路漫漫其修远矣。