博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
html5的自定义data-*属性和jquery的data()方法的使用示例
阅读量:6421 次
发布时间:2019-06-23

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

人们总喜欢往HTML标签上添加自定义属性来存储和操作数据。

但这样做的问题是,你不知道将来会不会有其它脚本把你的自定义属性给重置掉,此外,你这样做也会导致html语法上不符合Html规范,以及一些其它副作用。

这就是为什么在HTML5规范里增加了一个自定义data属性,你可以拿它做很多有用的事情。

 

 

你可以去读一下HTML5的详细规范,但这个自定义data属性的用法非常的简单,就是你可以往HTML标签上添加任意以 "data-"开头的属性,这些属性页面上是不显示的,它不会影响到你的页面布局和风格,但它却是可读可写的。

下面的一个代码片段是一个有效的HTML5标记:

代码如下:

Some awesome data
 

  

可是,怎么来读取这些数据呢?

你当然可以遍历页面元素来读取你想要的属性,但jquery已经内置了方法来操作这些属性。

使用jQuery的.data()方法来访问这些"data-*" 属性。

其中一个方法就是 .data(obj),这个方法是在 jQuery1.4.3版本后出现的,它能返回相应的data属性。

举个例子,你可以用下面的写法读取 data-myid属性值:

代码如下:

var myid=jQuery("#awesome").data('myid');console.log(myid);

  

你还可以在"data-*" 属性里使用json语法,

例如,如果你写出下面的html:

代码如下:

  

你可以通过js直接访问这个数据,通过json的key值,你能得到相应的value:

代码如下:

var gameStatus=jQuery("#awesome-json").data('awesome').game;console.log(gameStatus);

  

你也可以通过.data(key,value)方法直接给"data-*" 属性赋值。

一个重要的你要注意的事情是,这些"data-*" 属性应该和它所在的元素有一定的关联,不要把它当成存放任意东西的存储工具。

补充:尽管"data-*" 是HTML5才出现的属性,但jquery是通用的,所以,在非HTML5的页面或浏览器里,你仍然可以使用.data(obj)方法来操作"data-*" 数据

 

 

原文:http://www.52ij.com/jishu/javascript/162336.html

转载地址:http://djlra.baihongyu.com/

你可能感兴趣的文章
没有对比就没有伤害!有一种爸爸叫别人家的爸爸
查看>>
在安卓上运行TensorFlow:让深度学习进入移动端
查看>>
技术助力第三次革命
查看>>
《HTML与CSS入门经典(第8版)》——2.6 总结
查看>>
新手指南:在 Ubuntu 和 Fedora 上安装软件包
查看>>
在 CentOS7.0 上搭建 Chroot 的 Bind DNS 服务器
查看>>
《动手搭建智能家居系统》——1.2 安全管理和居家护理自动化
查看>>
《Python高性能编程》——2.2 Julia集合的介绍
查看>>
大型网站的 HTTPS 实践(二):HTTPS 对性能的影响
查看>>
《Swift 权威指南》——第6章,第6.10节嵌套函数
查看>>
git add . 的时候遇到warning: LF will be replaced by CRLF in ...... 解决办法
查看>>
《自己动手做交互系统》——1.3 本章小结
查看>>
Mobile devices bundled with malware?
查看>>
《Node应用程序构建——使用MongoDB和Backbone》一导读
查看>>
《JavaScript面向对象精要》——1.5 访问属性
查看>>
《Python数据可视化编程实战》—— 第 1 章 准备工作环境
查看>>
Android应用性能优化最佳实践.1.1 Android Studio的优势
查看>>
《设计模式解析(第2版•修订版)》—第2章 2.2节什么是UML
查看>>
【健康医疗】4步完成数据分析报表,让医疗数据转化为生产力
查看>>
【直播】APP全量混淆和瘦身技术揭秘
查看>>