首页 > 其他分享 >js: 获取标签元素data-*属性值的方法

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

时间:2023-01-12 13:23:26浏览次数:45  
标签:console log 标签 js user data id 属性

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

彭世瑜

于 2022-05-23 09:59:50 发布

2165
 收藏 1
文章标签: javascript 前端 jquery
版权
标签上有两个属性data-id 和 data-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>

————————————————
版权声明:本文为CSDN博主「彭世瑜」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/mouday/article/details/124921672
js: 获取标签元素data-*属性值的方法

彭世瑜

于 2022-05-23 09:59:50 发布

2165
 收藏 1
文章标签: javascript 前端 jquery
版权
标签上有两个属性data-id 和 data-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>

————————————————
版权声明:本文为CSDN博主「彭世瑜」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/mouday/article/details/124921672

 

标签:console,log,标签,js,user,data,id,属性
From: https://www.cnblogs.com/webSnow/p/17046369.html

相关文章

  • jQuery的css(操作样式标签,找到元素位置 p15~p17 and p19)
    视频CSS<!DOCTYPEhtml><html><head><metacharset="UTF-8"><title>11_css</title></head><body><pstyle="color:blue;">尚硅谷的后裔</p><pstyle="colo......
  • JS_1_引入js、js变量
    JavaScript,脚本语言,基于HTML,使得网页能够实现与用户的互动。 一、引入js代码1、在html中声明js代码域:<scripttype="text/javascript">js代码...</script>2......
  • js数组去重常见的七种方法
      参考:https://blog.csdn.net/Lguorong/article/details/124301325......
  • node -e "require('nan')" npm 安装 tty.js 时报错 ,解决方法
    ubuntu14.04上报错解决办法:sudoapt-getupdate&&sudoapt-getinstallnodejs-legacy......
  • js的面向对象
    前言说起起面向对象的概念,大家大部分的印象都是与后端相关的。  其实并不是这样,我觉得面-向对象这种思想适合在任何的场景,甚至在现实的场景中。因为后端相关语言在实......
  • rollupjs
    掉落神坛的webpackwebpack诞生之初的根本原因就是处理前端js模块化的工具。如果浏览器本身慢慢的已经支持了模块化。那么webpack存在的意义就不大了。webpack的其它瑕......
  • 【javascript】关于 canvas.toDataURL()
    在工作中遇到了奇怪的问题,在此记录。 一、定义canvas.toDataURL()方法是返回一个包含图片展示的数据URL。可以使用 type 参数其类型,默认为PNG格式,图片的分辨率为9......
  • SpringDataJpa的四种查询方式详解
    SpringDataJpa的四种查询方式详解原文连接:https://www.php1.cn/detail/SpringDataJpa_De_c944e232.html一、调用接口的方式(JpaRepository第一个接口里面定义了一些简......
  • Leaflet.js | Map类属性与方法
    1、初始化L.map(<String>id,options?)//用地图div的id创建L.map(<HTMLElement>el,options?)//用地图div的name创建//简单示例//initializethemaponthe......
  • Leaflet.js | 官方控件Control
    1、比例控件一个简单的比例控件,以公制(m/km)和英制(mi/ft)系统显示当前屏幕中心的比例,可扩展。使用示例L.control.scale().addTo(map);创造构造描述L.contr......