原标题:HTML5 Custom Data Attributes (data-*)

你是否曾经使用 class 或 rel 来保存任意的元数据,只为了使你的JavaScript更简单?如果你回答是的,那么我有一个令人激动的消息要告诉你!如果你回答不是,并且你还想,“咦,这个主意不错哦~”,那我劝你尽早放弃这个幼稚的想法,并看完本文。

多亏了HTML5,我们可以嵌入自定义的 data 属性给所有的HTML元素。这个 data 属性包含两部分:

属性名

属性名以'data-'前缀开头,并且至少要有一个字符。不可以包含大写字母。

属性值

属性值可以是任何字符串。

根据这个语法,我们可以添加应用数据信息给标签,如下所示:

<ul id="vegetable-seeds">
<li data-spacing="10cm" data-sowing-time="March to June">Carrots</li>
<li data-spacing="30cm" data-sowing-time="February to March">Celery</li>
<li data-spacing="3cm" data-sowing-time="March to September">Radishes</li>
</ul>

我们现在可以在JavaScript中使用这些保存的数据来创造更丰富有趣的用户体验。试想一下,当用户点击一颗蔬菜,一个新面板打开,向用户显示额外的种子间距和播种指示信息。因为有了data-属性,我们可以将数据添加给<li>标签,从而展示数据的时候不必进行Ajax,也不必进行服务器端的数据库查询,可以直接从属性中获取数据。

在自定义属性前使用data-前缀可以确保它会被浏览器忽略。对于浏览器和网站实际上的最终用户而言,该数据不存在。

标准上是这样说的(我们强调):

自定义数据属性用于存储网页或应用程序的私有自定义数据,因为没有更合适的属性或元素。
这些属性不适用于独立于使用这些属性的网站的软件。
每个HTML元素都可以有任意数量的自定义属性与任何值。
 
如何使用?
 
因为自定义属性是HTML5,所以他们可以在任何支持HTML5的浏览器中使用。这便是全部了。除了协助向后兼容以外,这也确保自定义数据属性在未来仍将是一个可扩展的、跨平台的解决方案。
现在我们对数据属性有一个宽泛的理解,让我们看看他们如何使用:
  • 存储可能需要在以后的JavaScript动画计算的元素的初始高度或不透明度
  • 存储通过JavaScript加载的Flash动画的参数
  • 存储自定义的网页标签数据,如同Jason Karns展示的
  • 存储一个元素的健康,弹药或生命数据,在JavaScript游戏中
  • 推动访问JavaScript <video>字幕,如同Bruce Lawson展示的

不应该做什么?

 
尽管很灵活,但数据属性并不适合解决所有问题。
  • 如果有一个现有的属性或元素,适合你的数据存储,则不应使用数据属性。比如,在一个时间,日期/时间数据应该存放在语义化的时间元素里而不是存储在自定义数据属性里。
  • 自定义数据属性不打算与微格式竞争。这在标准中清楚地说明了,数据不适合公开数据使用。外部软件不应与它进行交互。标记联系人详细信息或事件的细节使用自定义属性的数据是错的,当然,除非它是只供你自己的内部脚本使用。
  • 特定数据属性的存在或缺失不应被用作任何样式的CSS钩子。这样做表明你存储的数据对用户而重要,应使用更语义化的标记。

通过JavaScript使用data-*属性

既然我们懂得了自定义数据属性是什么,以及我们什么时候可以使用它,现在我们应该看看我们如何使用JavaScript与它交互。
如果我们想使用原生JavaScript获取或修改这些属性,那么我们可以使用getAttribute和setAttribute方法,如下所示:
<div id='strawberry-plant' data-fruit='12'></div>

<script>
// getAttribute 获取数据属性
var plant = document.getElementById('strawberry-plant');
var fruitCount = plant.getAttribute('data-fruit'); // fruitCount = '12' // setAttribute 设置数据属性
plant.setAttribute('data-fruit','7'); // 因为该死的鸟……
</script>
此方法将在所有现代浏览器工作,但它不是数据属性原本的用法。第二个(新的和改进的)方式来实现同样的事情是通过访问一个元素的数据集属性。此数据集属性——新HTML5 JavaScript API的一部分——将返回所有选定的元素的数据属性的一个DOMStringMap对象。使用这种方法,不必使用完整的属性的名称,你可以抛弃数据前缀,直接使用自己定义的名称。属性的名称将会转换为驼峰命名式的名称。
<div id='sunflower' data-leaves='47' data-plant-height='2.4m'></div>

<script>
// dataset 获取属性
var plant = document.getElementById('sunflower');
var leaves = plant.dataset.leaves; // leaves = 47; // 'dataset 设置属性
var tallness = plant.dataset.plantHeight; // 'plant-height' -> 'plantHeight'
plant.dataset.plantHeight = '3.6m'; // 超级肥料!
</script>
如果某个数据属性不再需要,也可以通过设置它为null来完全移除该属性。
plant.dataset.leaves = null; // 毛毛虫攻击!
不幸的是,新的数据集属性尚未被所有浏览器中支持,所以同时最好如前面所示使用getAttribute和setAttribute。
开发应用程序时,你发现能够通过自定义的数据属性的值来选择元素。这可以快速、轻松地使用querySelectorAll实现,如下所示:
// 选择所有带有 'data-flowering' 属性的元素
document.querySelectorAll('[data-flowering]'); // 选择所有红叶子的元素
document.querySelectorAll('[data-foliage-colour="red"]');

最后一句忠告

 
随着数据属性越来越广泛的应用,发生命名冲突的可能性变得更大。如果你使用一个缺乏想象力的属性名称,如data-height,那么很可能你最终会遇到一个库或插件,它使用相同的属性名称。多个脚本获取和设置一个常见的数据属性可能会导致混乱。为了避免这种情况,我建议人们选择一个标准字(也许是该网站/插件的名称)作为所有数据属性的前缀, 比
data-html5doctor-height 或者 data-my-plugin-height。
 
总结
 
自定义数据属性是一个用来简化网页中的应用程序数据的存储的很棒的方式。虽然你还不能只是利用新的javascriptAPI,但你可以享受getAttribute和setAttribute的便利,他们可以在所有主流浏览器上工作。

原文地址:http://html5doctor.com/html5-custom-data-attributes/

【翻译】详解HTML5 自定义 Data 属性的更多相关文章

  1. HTML5自定义data属性

    可能大家在使用jquery mobile时,经常会看到data-role.data-theme等的使用,比如:通过如下代码即可实现页眉的效果: [html] <div data-role=&qu ...

  2. 【转载】HTML5自定义data属性

    可能大家在使用jquery mobile时,经常会看到data-role.data-theme等的使用,比如:通过如下代码即可实现页眉的效果:   [html]  <div data-role= ...

  3. 详解HTML5中rel属性的prefetch预加载功能使用

    在HTML5中,有个很有用但常被忽略的特性,就是预先加载(prefetch),它的原理是: 利用浏览器的空闲时间去先下载用户指定需要的内容,然后缓存起来,这样用户下次加载时,就直接从缓存中取出来,效率 ...

  4. [转]人人网首页拖拽上传详解(HTML5 Drag&Drop、FileReader API、formdata)

    人人网首页拖拽上传详解(HTML5 Drag&Drop.FileReader API.formdata) 2011年12月11日 | 彬Go 上一篇:给力的 Google HTML5 训练营( ...

  5. 详解 javascript中offsetleft属性的用法(转)

    详解 javascript中offsetleft属性的用法 转载  2015-11-11   投稿:mrr    我要评论 本章节通过代码实例介绍一下offsetleft属性的用法,需要的朋友可以做一 ...

  6. (转载)详解Javascript中prototype属性(推荐)

    在典型的面向对象的语言中,如java,都存在类(class)的概念,类就是对象的模板,对象就是类的实例.但是在Javascript语言体系中,是不存在类(Class)的概念的,javascript中不 ...

  7. js(jQuery)获取自定义data属性的值

    有时候因为需要在标签上设置自定义data属性值, <div class="col-sm-6 col-md-4" id="get_id" data-c_id ...

  8. Net is as typeof 运行运算符详解 net 自定义泛型那点事

    Net is as typeof 运行运算符详解   概述 在了解运行运算符的前提我们需要了解什么是RTTI ,在任何一门面向对象的语言中,都有RTTI这个概念(即 运行时). RTTI(Run-Ti ...

  9. $.ajax()方法详解 ajax之async属性 【原创】详细案例解剖——浅谈Redis缓存的常用5种方式(String,Hash,List,set,SetSorted )

    $.ajax()方法详解   jquery中的ajax方法参数总是记不住,这里记录一下. 1.url: 要求为String类型的参数,(默认为当前页地址)发送请求的地址. 2.type: 要求为Str ...

随机推荐

  1. for循环、列表的切片、元组

    一.遍历整个列表 使用for语句循环将列表每取出一个变量,然后存储在中间变量中,打印中间变量:循环取出: 1.简单for循环 示例: carssa = ['richan','fengtian','be ...

  2. IDEA 快捷键 (长期更新)

    自动清除无效 import 和 清除无效 import  ctrl+alt+o    

  3. 《剑指offer》面试题27 二叉搜索树与双向链表 Java版

    (将BST改成排序的双向链表.) 我的方法一:根据BST的性质,如果我们中序遍历BST,将会得到一个从小到大排序的序列.如果我们将包含这些数字的节点连接起来,就形成了一个链表,形成双向链表也很简单.关 ...

  4. link标签中的integrity和crossorigin字段

    https://blog.csdn.net/SNP_fuyun/article/details/77113985?locationNum=10&fps=1

  5. 高效编程之 多线程Event

    Event 简介 Event 事件 是线程间通信的最简单方法之一,主要用于线程同步. 处理机制 定义一个全局内置标志Flag,如果Flag为False,执行到 event.wait 时程序就会阻塞,如 ...

  6. 最长公共子序列(LCS) Medium2

    The company "21st Century Fruits" has specialized in creating new sorts of fruits by trans ...

  7. spring boot 枚举使用的坑

    java 枚举的功能挺多,但是坑更多,使用的时候要注意.如下面这个枚举. @Getter @AllArgsConstructor public enum EnumExpenseType impleme ...

  8. phpstorm配置成sublime的代码高亮逼格风格

    使用sublime text3的风格来编程感觉是相当逼格的,然而在php的时候还是觉得phpstorm用起来更顺手一点. 正好在phpstorm中也有配置sublime类似风格的插件,这里来教大家如何 ...

  9. Vue中如何引入第三方icon库(阿里巴巴矢量图标库)

    1.进入阿里巴巴矢量图标库: 2.新建项目 3.前缀注意不要跟element-ui自带的icon(el-icon)重名就ok 4.创建完成后,去阿里选自己要使用的图标,加入购物车           ...

  10. Datatable中对某列求和,三种不同情况下的方法

    C# code 方法一. object sumObject = DataTable.Compute("sum(Qty)", "TRUE"); 直接对数据表中的字 ...