js: 获取标签元素data-*属性值的方法

举报
彭世瑜 发表于 2022/05/23 23:16:32 2022/05/23
【摘要】 标签上有两个属性data-id 和 data-user-name, 需要通过js去获取 <style> #user::before { content: attr(data-i...

标签上有两个属性data-iddata-user-name, 需要通过js去获取

 <style>
  #user::before {
    content: attr(data-id);
  }

  #user::after {
    content: attr(data-user-name);
  }
</style>


<div id="user" data-id="666" data-user-name="Tom"></div>


  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

方式一:dataset

let user = document.querySelector("#user");

// 取值 中划线要转为驼峰命名法 
console.log(user.dataset.id); // 666
console.log(user.dataset.userName); // Tom

// 赋值
user.dataset.id = 777;
user.dataset.userName = "Jack";

// 新增属性
user.dataset.age = 23;

// 删除属性
delete user.dataset.userName;
// <div id="user" data-id="777" data-age="23"></div>

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

方式二: getAttribute/setAttribute/removeAttribute

let user = document.querySelector("#user");

// 取值
console.log(user.getAttribute("data-id")); // 666
console.log(user.getAttribute("data-user-name")); // Tom
console.log(typeof user.getAttribute("data-id")); // string

// 赋值
user.setAttribute("data-id", 777);

// 新增属性
user.setAttribute("data-age", 23);

// 删除属性
user.removeAttribute("data-user-name");
// <div id="user" data-id="777" data-age="23"></div>

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

方法三:jQuery.attr

<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js"></script>

<script>
  let user = $('#user');

  // 取值
  console.log(user.attr("data-id")); // 666
  console.log(user.attr("data-user-name")); // Tom
  
  // 赋值
  user.attr("data-id", 777);

  // 新增属性
  user.attr("data-age", 23);

  // 删除属性
  user.removeAttr("data-user-name");
  // <div id="user" data-id="777" data-age="23"></div>
</script>

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19

方法四:jQuery.data

注意:$.data()的值进行修改并不会影响到DOM元素上的data-*属性的改变

<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js"></script>

<script>
  let user = $("#user");

  // 取值
  console.log(user.data("id")); // 666
  console.log(user.data("user-name")); // Tom
    
  // 赋值
  user.data("id", 777);

  // 新增属性
  user.data("age", 23);

  // 删除属性
  user.removeData("user-name");
  
  console.log(user.data());
  // {id: 777, age: 23, userName: 'Tom'}
  // data() 操作没有影响到dom元素的属性变化
  // <div id="user" data-id="666" data-user-name="Tom"></div>
</script>

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23

参考
jQuery获取data-*属性值下面就详细介绍四种方法获取data-*属性的值

文章来源: pengshiyu.blog.csdn.net,作者:彭世瑜,版权归原作者所有,如需转载,请联系作者。

原文链接:pengshiyu.blog.csdn.net/article/details/124921672

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

举报
请填写举报理由
0/200