博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用HTML5中的element.dataset操作自定义data-*数据
阅读量:7281 次
发布时间:2019-06-30

本文共 1198 字,大约阅读时间需要 3 分钟。

不久之前我向大家展示了非常有用的,它是一种HTML5里提供的原生的对页面元素的CSS类进行增、删改的接口,完全可以替代jQuery里的那些CSS类操作方法。而另外一个非常有用的API就是 ,从火狐6和Chrome8起就开始对它有了支持。这个简单的API能够让用户getsetHTML页面元素上的data-*属性。下面我们来看看它是如何使用的!

想必大家都知道,我们可以给HTML元素添加自定义的data-*属性。你可以给这个属性起任何名字,但在使用element.dataset API时你需要主要以下一些规则:

  • element.dataset不能够直接拿来用,否者你会遇到报错提示
  • 用JavaScript里使用data-*属性名时,要把名称转变成驼峰式命名(Camel-Case)
  • 名称不能以xml打头
  • 名称里不能有大写字母

假设页面里有下面的元素存在:

  要想获取这个data-id属性,你的代码应该写成这样:

// Get the elementvar element = document.getElementById("myDiv");// Get the idvar id = element.dataset.id;

  要想获取data-my-custom-key属性值,你的代码应该写成这样:

// Retrieves "data-my-custom-key"var customKey = element.dataset.myCustomKey;

  给自定义属性赋值的方法是这样的:

// Sets the value to something elseelement.dataset.myCustomKey = "Some other value";// Element would be://		

  如果一个自定义属性并不存在,但在程序中你给它赋值,它会自动创建:

// Set new data- attributeelement.dataset.mootoolsFtw = "true";// Element would be://		
//

  也许你会认为data-*属性里可以存放对象,但事实上不行,dataset不会初始化这些对象。我不清楚dataset对长度的限制,但在里面存放大量的数据必定会是DOM变得臃肿不堪,很难调试。喜欢使用jQuery的朋友应该知道jQuery里也有相应的$.data()方法,没错,HTML5里的这个原生的dataset就是来替代它的,如果你的页面只需要简单的操作data-*自定义属性,就不需要引入这些体积越来越多的jQuery工具库了,不是吗?

转载于:https://www.cnblogs.com/xupeiyu/p/5985703.html

你可能感兴趣的文章
Windows Phone 7 Tips (5)
查看>>
解决C++代码单元测试中的难题-不可验证和IO调用
查看>>
对公司网站DNS解析异常的排查与处理
查看>>
visual assist 1837 支持vs2010
查看>>
android用户界面-菜单
查看>>
Mdaemon邮件服务器作为Exchange反垃圾网关部署方案
查看>>
快速更改Windows 7桌面显示
查看>>
Vlookup函数的两个使用案例分享
查看>>
常用界面布局(LinearLayout以此做的DEMO)
查看>>
【移动开发】Android中Theme和Style的使用
查看>>
TrieTree服务续篇 - 组件构成及其作用
查看>>
Linux管道命令
查看>>
MySQL 转换函数与运算符
查看>>
针对RemoteFX的Quadro
查看>>
FileItem 出现部分中文乱码解决办法
查看>>
zabbix 报警小案例
查看>>
Google Developing for Android 学习总结
查看>>
在centos7中添加一个新用户,并授权
查看>>
SWIFT中函数返回值为Tuple
查看>>
使用脚本实现登录时的Num Lock 状态
查看>>