JavaScript 自定义属性 data-*使用介绍

 更新时间:2023年06月09日 00:56:15   作者:memeflyfly  
Html5规范中规定自定义属性需要添加前缀data-,目的是提供与渲染无关的信息,读取的时候是通过dataset对象,使用”.”来获取属性,需要去掉data-前缀

JavaScript 自定义属性 data-*

定义和用法

data-* 属性用于存储页面或应用程序的私有自定义数据。

data-* 属性赋予我们在所有 HTML 元素上嵌入自定义 data 属性的能力。

存储的(自定义)数据能够被页面的 JavaScript 中利用,以创建更好的用户体验(不进行 Ajax 调用或服务器端数据库查询)。

data-* 属性包括两部分:

  1. 属性名不应该包含任何大写字母,并且在前缀 "data-" 之后必须有至少一个字符
  2. 属性值可以是任意字符串

注释:用户代理会完全忽略前缀为 "data-" 的自定义属性。

HTML 4.01 与 HTML5 之间的差异

data-* 属性是 HTML5 中的新属性。

语法

<element data-*="somevalue">

属性值

描述
somevalue规定属性的值(以字符串)。

实例

function showDetails(element) {
      var elementType = element.getAttribute("data-type");
      alert(element.innerHTML + "是" + elementType + "属性角色");
    }
  <h1>角色</h1>
  <p>点击某个角色来查看其属性:</p>
  <ul>
    <li onclick="showDetails(this)" id="fire" data-type="火">迪卢克</li>
    <li onclick="showDetails(this)" id="thunder" data-type="雷">菲谢尔</li>
    <li onclick="showDetails(this)" id="water" data-type="水">芭芭拉</li>
  </ul>

使用dataset属性操作自定义属性

function showDetails(element) {
    var elementType = element.getAttribute("data-type");
    var h3 = document.getElementsByTagName('h3')[0]
    alert(element.innerHTML + "是" + elementType + "属性角色");
    h3.innerHTML = element.dataset.type
  }
<h1>角色</h1>
  <p>点击某个角色来查看其属性:</p>
  <ul>
    <li onclick="showDetails(this)" id="fire" data-type="火">迪卢克</li>
    <li onclick="showDetails(this)" id="thunder" data-type="雷">菲谢尔</li>
    <li onclick="showDetails(this)" id="water" data-type="水">芭芭拉</li>
  </ul>
  <h3></h3>

在函数中alert语句前添加一行代码,对将被点击的元素的data-type赋值

element.dataset.type = '不知道啥属性'

<h1>角色</h1>
  <p>点击某个角色来查看其属性:</p>
  <ul>
    <li onclick="showDetails(this)" id="fire" data-type="火">迪卢克</li>
    <li onclick="showDetails(this)" id="thunder" data-type="雷">菲谢尔</li>
    <li onclick="showDetails(this)" id="water" data-type="水">芭芭拉</li>
  </ul>
  <h3></h3>
<script> 
function showDetails(element) {
    var elementType = element.getAttribute("data-type");
    var h3 = document.getElementsByTagName('h3')[0]
	element.dataset.type = '不知道啥属性'
    alert(element.innerHTML + "是" + elementType + "属性角色");
    h3.innerHTML = element.dataset.type
  }
</script> 

js获取自定义属性data-

Html5规范中规定自定义属性需要添加前缀data-,目的是提供与渲染无关的信息。

读取的时候是通过dataset对象,使用”.”来获取属性,需要去掉data-前缀

<div id="content" data-age="18">12345</div>
var content= document.getElementById('content');
alert(content.dataset.age)
//jquery
$('#content').data('age');//读

字符需要转化为驼峰命名

<div id="content" data-user-list="user_list">data-user_list自定义属性 </div>
var content= document.getElementById('content');
alert(content.dataset.userList)
//jquery
$('#content').data('userList');//读

到此这篇关于jQuery 获取与设置元素属性的详细方法(看完这篇文章就搞明白了)的文章就介绍到这了,更多相关jQuery 获取与设置元素属性内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 详解如何优雅迭代JavaScript字面对象

    详解如何优雅迭代JavaScript字面对象

    迭代是访问集合元素的一种方法,可以被迭代的对象称为可迭代对象,下面这篇文章主要给大家介绍了关于如何优雅迭代JavaScript字面对象的相关资料,需要的朋友可以参考下
    2022-05-05
  • js Dom实现换肤效果

    js Dom实现换肤效果

    这篇文章主要为大家详细介绍了js Dom实现换肤效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-10-10
  • js 获取html5的data属性实现方法

    js 获取html5的data属性实现方法

    下面小编就为大家带来一篇js 获取html5的data属性实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-07-07
  • js+canvas实现动态吃豆人效果

    js+canvas实现动态吃豆人效果

    本文主要介绍了js+canvas实现动态吃豆人效果的实例。具有很好的参考价值。下面跟着小编一起来看下吧
    2017-03-03
  • JavaScript基础之this和箭头函数详析

    JavaScript基础之this和箭头函数详析

    这篇文章主要给大家介绍了关于JavaScript基础之this和箭头函数的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用JavaScript具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-09-09
  • 深入解析Javascript闭包的功能及实现方法

    深入解析Javascript闭包的功能及实现方法

    这篇文章主要为大家详细解析Javascript闭包的功能及实现方法,感兴趣的小伙伴们可以参考一下
    2016-07-07
  • JS实现的简单表单验证功能完整实例

    JS实现的简单表单验证功能完整实例

    这篇文章主要介绍了JS实现的简单表单验证功能,结合完整实例形式分析了javascript基于字符串长度判定、数据类型判定及正则判断等操作进行表单验证的相关实现技巧,需要的朋友可以参考下
    2017-10-10
  • 如何从零开始利用js手写一个Promise库详解

    如何从零开始利用js手写一个Promise库详解

    ES2015 推出了JS 的 Promise ,而在没有原生支持的时候,我们也可以使用诸如 Promises/A+ 的库的帮助,在我们的代码里实现Promise 的支持,下面这篇文章主要给大家介绍了如何从零开始利用js手写一个Promise库的相关资料,需要的朋友可以参考下。
    2018-04-04
  • javascript 函数限制调用代码

    javascript 函数限制调用代码

    javascript 函数限制调用代码,需要的朋友可以参考下。
    2010-05-05
  • 基于JS实现翻书效果的页面切换样式

    基于JS实现翻书效果的页面切换样式

    在项目开发中经常遇到翻书的页面切换效果,基于js代码怎么实现的呢?今天小编给大家分享基于JS实现翻书效果的页面切换样式,需要的朋友参考下吧
    2017-02-02

最新评论