data-* - HTML(超文本标记语言)

Secret agents
- Jason Walters, 003: Found dead in "A View to a Kill".
-
Alex Trevelyan, 006: Agent turned terrorist leader; James' nemesis in
"Goldeneye".
-
James Bond, 007: The main man; shaken but not stirred.
h1 {
margin: 0;
}
ul {
margin: 10px 0 0;
}
li {
position: relative;
width: 200px;
padding-bottom: 10px;
}
li:after {
content: "Data ID: " attr(data-id);
position: absolute;
top: -22px;
left: 10px;
background: black;
color: white;
padding: 2px;
border: 1px solid #eee;
opacity: 0;
transition: 0.5s opacity;
}
li:hover:after {
opacity: 1;
}
所有这些自定义数据属性都可以通过所属元素的 HTMLElement 接口来访问。HTMLElement.dataset 属性可以访问它们。* 可以使用遵循 XML 名称生产规则 的任何名称来被替换,并具有以下限制:
该名称不应以 xml 开头(不区分大小写),因为它是为未来的 XML 规范保留的。
该名称不应包含任何冒号字符(:),因为 XML 会赋予此类名称意义。
该名称不应包含任何大写字母,因为 XML 都是小写字母。
这些都是建议。如果不遵循这些命名建议,将不会发生错误。属性仍将使用 CSS 属性选择器进行匹配,属性不区分大小写,任何属性值都区分大小写。不符合这三项建议的属性仍将被 JavaScript HTMLElement.dataset 属性识别,用户代理将把该属性包含在包含 HTMLElement 的所有自定义数据属性的 DOMStringMap 中。
如果计划使用 HTMLElement.dataset,那么属性名中 data- 后面的部分只能包含 JavaScript 属性名中允许使用的字符(以及连字符,连字符将被删除)。属性名的 dataset 版本会去掉“data-”前缀,并将名称的其余部分从烤串命名法转换为驼峰命名法。例如,element.getAttribute("data-test") 等同于 element.dataset.test,而 data-test-abc 将以 HTMLElement.dataset.testAbc(或 HTMLElement.dataset["testAbc"])的形式访问。避免使用连字符后的非字母字符,如 data-test-1 或 data--test,因为 HTMLElement.dataset 无法识别这些字符。