js读取data-属性
标签上有两个属性data-id 和 data-user-name, 需要通过js去获取
|
1
2
3
4
5
6
7
8
9
|
<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> |
方式一:dataset
|
1
2
3
4
5
6
7
8
9
10
11
12
13
|
let user = document.querySelector("#user");// 取值 中划线要转为驼峰命名法console.log(user.dataset.id); // 666console.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> |
方式二: getAttribute/setAttribute/removeAttribute
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
let user = document.querySelector("#user");// 取值console.log(user.getAttribute("data-id")); // 666console.log(user.getAttribute("data-user-name")); // Tomconsole.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> |
方法三:jQuery.attr
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
<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")); // 666console.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> |
方法四:jQuery.data
注意:$.data()的值进行修改并不会影响到DOM元素上的data-*属性的改变
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
<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")); // 666console.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> |
浙公网安备 33010602011771号