【js: 获取标签元素data-*属性值的方法】亦余心之所善兮,虽九死其犹未悔。这篇文章主要讲述js: 获取标签元素data-*属性值的方法相关的知识,希望能为你提供帮助。
标签上有两个属性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>
方式一: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>
方式二: 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>
方法三:jQuery.attr
<
script src="http://img.readke.com/220615/1649192T9-0.jpg">
<
/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>
方法四:jQuery.data注意:$.data()的值进行修改并不会影响到DOM元素上的data-*属性的改变
<
script src="http://img.readke.com/220615/1649192T9-0.jpg">
<
/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>
推荐阅读
- 用IntelliJ IDEA ULTIMATE版看Java类图
- JS 的浪漫 ——Promise 食用注意点
- 数字孪生智慧物流之 Web GIS 地图应用
- C语言实战小项目通讯录
- 硬件开发笔记(硬件开发基本流程,制作一个USB转RS232的模块:开发基本过程和元器件选型)
- #yyds干货盘点# 解决剑指offer(数组中的逆序对)
- Windows更新报错0x80246008
- 小胖学Linux day42~43(NFS共享存储)
- 80%的 Linux 使用者都不懂的内存问题