最新消息:觉得本站不错的话 记得收藏哦 博客内某些功能仅供测试 讨论群:135931704 快养不起小站了 各位有闲钱就打赏下把 My Email weicots#gmail.com Please replace # with @

HTML 5 data-* 属性

FEE ajiang-tuzi 4130浏览

HTML 5的Data属性可以让你给元素自定义数据。这篇文章就是思考怎么更好的使用Data属性。

介绍

HTML 5之前,我们必须依赖于class和rel属性来存储需要在网站中使用的数据片段,这种做法有时会在网站的外观和实用性之间产生冲突。而HTML 5 Data属性的存在就能很好满足需要。

随着网站自身的数据越来越多,一些特定的元素也开始保存数据了。比如,要创建一个audio应用,代码如下:

<audio controls="controls">
  <source src="track1.mp3" type="audio/mpeg" />
</audio>

上面的代码是完全能够接受的,但是有时我们需要保存时长、速度和作者等更多关于音频本身的信息,而不是音频来源。这就需要用到Data属性了,示例如下:

<audio controls="controls">
  <source src="track1.mp3" type="audio/mpeg" data-duration="1min5secs" data-tempo="125bpm" data-artist="The Beatles" />
</audio>

通过这些自定义的Data属性,就能够对audio执行搜寻、过滤以及分组等动作。

怎么使用Data属性

自定义的Data属性的名字必须以data-开头,并且连字号后面至少要有一个符合HTML规范的字符。(HTML naming convention.)

W3C文档对Data属性的说明如下:

Custom data attributes are intended to store custom data private to the page or application, for which there are no more appropriate attributes or elements.
这也意味着我们只能在应用程序内部使用data数据,而不应该将它呈现给用户。更重要的是你可以给元素自定义任何数量的Data属性,并赋予任何有意义的值。

什么时候需要使用Data属性?

通过上面的讲述,已经知道怎么使用Data属性了。但为了更好地了解这个属性,再看几个例子。

在Tuts+的Webdesign板块已经有了很好地、关于使用data属性的例子。One of the tuts,将Data属性运用到样式中,让菜单有一个“气泡”通知效果。在这个示例中,data属性被用于只想气泡通知的值。

<a href="#" class="pink" data-bubble="2">Profile</a>

另外一个示例:quick tip,Data属性作为提示信息是怎么被用于提示框的

<a href="#" class="tooltip" data-tip="this is the tip!">This is the link</a>

什么时候不该用Data属性?

当元素已经建立或者更适当的属性时,就不应该用Data属性了。在下面这个示例中运用data是不合适的:

<span data-time="20:00">8pm<span>

因为在一个表示时间的元素中,已经有一个datetime属性了:

<time datetime="20:00">8pm</time>

同时,Data属性不应该被用作一个可替代的元数据或者微格式。微格式主要是为人类设计的、用于介绍上下文信息的。比如,如果你有一张关于个人或者某个组织联系信息的Vcard,你应该赋予一个名为vcard的class属性,让机器明白它包含了一些联系的信息。

利用微格式的代码如下:

<div class="vcard">
    <span class="fn " >Aaron Lumsden</span>
</div>

相反,利用Data属性的代码如下:

<div class="vcard">
    <span data-name="Aaron Lumsden " >Aaron Lumsden</span>
</div>

了解更多关于微格式的信息:Mircorformats.org.

在CSS中使用Data属性

既然在HTML标记中实现了Data属性,那么也可以在CSS中使用这个属性了。注意:尽管在某些情况下更适合直接使用Data属性,那也不应该对任何样式规则直接使用该属性。简单的使用如下:

[data-role="page"] {
  /* Styles */
}

在JQuery中使用Data属性

在JQuery中怎么使用Data属性呢?JQuery提供了很多种从元素获取数据的方式。例如,像下面这样:

<a href="http://www.google.com" class="button" data-info="The worlds most popular search engine">Google</a>

如果有一个和上面类似的锚文本标记,有一个名为data-info的data属性,利用下面的方式,可以获取任何一个属性,包括data-info

$('.button').click(function(e) {
   e.preventDefault();
   thisdata = $(this).attr('data-info');
   console.log(thisdata);
 });

更多 例子 及描述

HTML5增加了一项新功能是自定义数据属性,也就是 data-*自定义属性。在HTML5中我们可以使用以data-为前缀来设置我们需要的自定义属性,来进行一些数据的存放。当然高级浏览器下可通过脚本进行定义和数据存取。在项目实践中非常有用。
例如:

<div id="user" data-uid="12345" data-uname="愚人码头"></div>

使用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'

// 使用setAttribute设置 data- 属性
user.setAttribute('data-site', 'http://www.weicot.com.com');

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

<div id="user" uid="12345" uname="愚人码头"></div>

<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.css88.com');
</script>

这种“原始”的自定义属性和上面data-*自定义属性没什么区别,知识属性名不一样。
dataset属性存取data-*自定义属性的值
这种方式通过访问一个元素的dataset属性来存取data-*自定义属性的值。这个dataset属性是HTML5 JavaScript API的一部分,用来返回一个所有选择元素data-属性的DOMStringMap对象。
和attributes方法比较:

data-*主要是对自定义属性做了标准化;循环取值的时候dataset属性比较方便,还有不是问题的问题就是自定义的attribute也不符合html规范(欢迎留言补充)。
使用这种方法时,不是使用完整的属性名,如data-uid来存取数据,应该去掉data-前缀。

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

<div id="user" data-id="1234567890" data-name="愚人码头" data-date-of-birth>码头</div>

<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>
<div class="user" data-id="123" data-name="feiwen">1</div>
<div class="user" data-id="124" data-name="css">码头</div>

本文 部分内容 收集自互联网 仅供学习和交流使用

转载请注明:(●--●) Hello.My Weicot » HTML 5 data-* 属性

蜀ICP备15020253号-1