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); // 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
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" )); // 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
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" )); // 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-*属性的改变
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" )); // 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> |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 【杂谈】分布式事务——高大上的无用知识?