使用HTML5中的 element.dataset 操作自定义 data-* 数据:

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

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

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

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

<div id="myDiv" data-name="myDiv" data-id="myId"
data-my-custom-key="This is the value"></div>

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

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

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

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

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

// Sets the value to something else
element.dataset.myCustomKey = "Some other value"; // Element would be:
// <div id="myDiv" data-name="myDiv" data-id="myId"
// data-my-custom-key="Some other value"></div>

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

// Set new data- attribute
element.dataset.mootoolsFtw = "true"; // Element would be:
// <div id="myDiv" data-name="myDiv" data-id="myId"
//data-my-custom-key="Some other value" data-mootools-ftw="true">
//</div>

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

转自:http://www.webhek.com/element-dataset-api/

最新文章

  1. Parallel并行之乱用
  2. linux mail 使用外部邮箱地址发邮件
  3. Sql Server按树形结构排序查询表记录
  4. 62. 链表重排[Reorder List]
  5. ADO,OLEDB,ODBC,DAO的区别【转】
  6. 服务器发布WebService返回DataTable
  7. line-height行高使用技巧
  8. GetCursorPos/WindowFromPoint/SendMessage
  9. 十款最佳Node.js MVC框架
  10. type 命令详解
  11. CSV的简单用法
  12. python 线程Queue 用法代码展示
  13. Jenkins pipeline 并行执行任务流
  14. Django 学习第九天——请求与响应
  15. Vue.directive基础,在Vue模块开发中使用
  16. Kafka:ZK+Kafka+Spark Streaming集群环境搭建(二十三)Structured Streaming遇到问题:Set(TopicName-0) are gone. Some data may have been missed
  17. 谈谈XAML前端开发
  18. Spring Aop、拦截器、过滤器的区别
  19. Django进阶(路由系统、中间件、缓存、Cookie和Session、Ajax发送数据
  20. Java学习笔记XML(3)

热门文章

  1. 51nod 1042 数字0-9的数量 数位dp
  2. python 等比数列
  3. ros 录制
  4. Oracle 12c Windows安装、介绍及简单使用(图文)
  5. js和css兼容问题
  6. English trip -- VC(情景课) 8 A Get ready
  7. Confluence 6 从外部目录中同步数据支持的目录类型
  8. Jon Snow and his Favourite Number CodeForces - 768C (技巧)
  9. A Creative Cutout CodeForces - 933D (计数)
  10. zabbix3.0.4 配置邮件报警