详解H5的自定义属性data-*

HTML5 增加了一项新功能是 自定义数据属性 ,也就是 data-* 自定义属性。在HTML5中我们可以使用以 data- 为前缀来设置我们需要的自定义属性,来进行一些数据的存放

当然高级浏览器下可通过脚本进行定义和数据存取。在项目实践中非常有用。

例如:

代码如下:

<p id = user data-uid = 12345 data-uname = 脚本之家 > </p>


使用attribute方法存取 data-* 自定义属性的值

使用attributes方法存取 data-* 自定义属性的值非常方便:

代码如下:

 // 使用getAttribute获取 data- 属性

  var user = 
document
 . getElementById ( 'user' ) ;

  var userName = plant . getAttribute ( 'data-uname' ) ; // userName = '脚本之家'

  var userId = plant . getAttribute ( 'data-uid' ) ; // userId = '12345'

  // 使用
set
Attribute设置 data- 属性

  user . setAttribute ( 'data-site' , 'http://www.jb51.net' ) ;


此方法能在所有的现代浏览器中正常工作,但它不是HTML 5 的自定义 data-*属性被使用目的,不然和我们以前使用的自定义属性就没有什么区别了,例如:

代码如下:

 <p id = user uid = 12345 uname = 脚本之家 > </p>

  <script>

  // 使用getAttribute获取 data- 属性

  var user = document . getElementById ( 'user' ) ;

  var userName = plant . getAttribute ( 'uname' ) ; // userName = '脚本之家'

  var userId = plant . getAttribute ( 'uid' ) ; // userId = '12345'

  // 使用setAttribute设置 data- 属性

  user . setAttribute ( 'site' , 'http://www.jb51.net' ) ;

  </script>


这种“原始”的自定义属性和上面 data-* 自定义属性没什么区别,知识属性名不一样。

dataset属性存取data-*自定义属性的值

这种方式通过访问一个元素的 dataset 属性来存取 data-* 自定义属性的值。这个 dataset 属性是HTML5 JavaScript API的一部分,用来返回一个所有选择元素 data- 属性的DOMStringMap对象

使用这种方法时,不是使用完整的属性名,如 data-uid 来存取数据,应该去掉data- 前缀。

还有一点特别注意的是: data- 属性名如果包含了连字符,例如:data-date-of-birth ,连字符将被去掉,并转换为驼峰式的命名,前面的属性名转换后应该是: dateOfBirth 。

代码如下:

 <p id=user data-id=1234567890 data-name=脚本之家 data-date-of-birth>码头</p>
  <script type=text/javascript>
  var el = document.querySelector('#user');
  console.log(el.id); // 'user'
  console.log(el.dataset);//一个DOMStringMap
  console.log(el.dataset.id); // '1234567890'
  console.log(el.dataset.name); // '脚本之家'
  console.log(el.dataset.dateOfBirth); // ''
  el.dataset.dateOfBirth = '1985-01-05'; // 设置data-date-of-birth的值.
  console.log('someDataAttr' in el.dataset);//false
  el.dataset.someDataAttr = 'mydata';
  console.log('someDataAttr' in el.dataset);//true
  </script>

如果你想删掉一个 data-属性 ,可以这么做: delete el . dataset . id ; 或者 el .dataset . id = null ; 。

看起来很美,哈哈,但是不幸的是,新的 dataset 属性只有在Chrome 8+ Firefox(Gecko) 6.0+ Internet Explorer 11+ Opera 11.10+ Safari 6+浏览器中实现,所以在此期间最好用的getAttribute和setAttribute来操作。

关于data-属性选择器

在实际开发时,您可能会发现它很有用,你可以根据自定义的 data- 属性选择相关的元素。例如使用querySelectorAll选择元素:

代码如下:


// 选择所有包含 'data-flowering' 属性的元素
document . querySelectorAll ( '[data-flowering]' ) ;

// 选择所有包含 'data-text-colour' 属性值为red的元素
document . querySelectorAll ( '[data-text-colour=red]' ) ;


同样的我们也可以通过 data- 属性值对相应的元素设置CSS样式,例如下面这个例子:

代码如下:

 <style type =text/css>

  .user {

  
width
 : 256px ;

  
height
 : 200px ;

  }

  .user[data-name='feiwen'] {

  color : brown

  }

  .user[data-name='css'] {

  color : red

  }

  </style>

  <p 
class
 = user data-id = 123 data-name = feiwen > 1 </p>

  <p class = user data-id = 124 data-name = css > 码头 </p>

【相关推荐】

1. Html5免费视频教程

2. 关于H5的事件属性详解

3. 详解H5非常重要的28个新特性,新技巧和新技术

4. H5制作一个计时器的代码演示

5. H5完成多图片上传的实例详解

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


HTML5和CSS3实现3D展示商品信息的代码
利用HTML5中的Canvas绘制笑脸的代码
Html5剪切板功能的实现
如何通过HTML5触摸事件实现移动端简易进度条
Html5移动端获奖无缝滚动动画实现
关于HTML5和CSS3实现机器猫的代码
HTML5使用DOM进行自定义控制
使用HTML5 Canvas绘制阴影效果的方法
使用PHP和HTML5 FormData实现无刷新文件上传
如何解决HTML5 虚拟键盘出现挡住输入框的问题
HTML5中div和section以及article的区别分析
html5和CSS 实现禁止IOS长按复制粘贴功能
html5 touch事件实现触屏页面上下滑动
canvas 模拟实现电子彩票刮刮乐的代码
HTML5 Plus 实现手机APP拍照或相册选择图片上传的功能
Android自定义环形LoadingView效果
HTML5 canvas绘制五角星的方法
html5使用html2canvas实现浏览器截图
使用Canvas处理图片的方法介绍
利用Canvas模仿百度贴吧客户端loading小球的方法