js獲取標簽元素data-*屬性值的4種方法
前言:
標簽上有兩個屬性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="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-*屬性的改變
<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>
到此這篇關於js獲取標簽元素data-*屬性值的4種方法的文章就介紹到這瞭,更多相關js獲取data-*屬性值內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- django學習之ajax post傳參的2種格式實例
- Django實現jquery select2帶搜索的下拉框
- JavaScript中子函數訪問外部變量的3種解決方法
- vue前端測試開發watch監聽data的數據變化
- SpringBoot實現api加密的示例代碼