您当前的位置: 首页 > 

彭世瑜

暂无认证

  • 7浏览

    0关注

    2791博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

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

彭世瑜 发布时间:2022-05-23 09:59:50 ,浏览量:7

标签上有两个属性data-iddata-user-name, 需要通过js去获取

 
  #user::before {
    content: attr(data-id);
  }

  #user::after {
    content: attr(data-user-name);
  }





方式一: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;
// 
方式二: 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");
// 
方法三:jQuery.attr



  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");
  // 
方法四:jQuery.data

注意:$.data()的值进行修改并不会影响到DOM元素上的data-*属性的改变




  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元素的属性变化
  // 

参考 jQuery获取data-*属性值下面就详细介绍四种方法获取data-*属性的值

关注
打赏
1665367115
查看更多评论
立即登录/注册

微信扫码登录

0.0575s