jquery怎么获得元素data属性值

2024-11-29 00:39:50
推荐回答(4个)
回答(1):

jQuery获取方法

  1. data()方法

  2. //HTML代码 

  3. //获取属性
    var appid = $("#myDiv").data("appid"); //123
    var app-id = $("#myDiv").data("app-id"); //456

  4. //属性赋值 $("#myDiv").data("appid","666");

  5. //最终HTML代码 

  6. 需要注意的是,data()的值进行修改并不会影响到DOM元素上的data-*属性的改变。data()的本质其实是将一个 “cache” 附加到了对象上,并使用了一个特殊的属性名称。

  7. 所以上述代码中,虽然对div进行了data()赋值操作,但HTML代码中div的data-appid的值仍然为123,因为data()只是修改了缓存的那个值,此时进行$('#myDiv').data("appid")的操作,输出的结果为666.

js获取data-*的方式

  • 通过dataset属性访问

    //HTML代码

    //js代码
    var div = document.getElementById("myDiv");
    var appId = div.dataset.appid;//获取data-appid的值
    var myName = div.dataset.myname;//获取data-myname的值
    //设置值
    div.dataset.appid = 456;
    div.dataset.myname = "newname";

    //最终HTML结果

  • dataset属性的值是DOMStringMap的一个实例,名值对的映射。每个data-name形式的属性都有一个对应的属性,只不过该属性名没有data-前缀。

    兼容性:

    需要注意的是,dataset中大小写的问题。带连字符连接的名称在使用的时候需要命名驼峰化。例如data-my-name对应的是dataset.myName的值。可看以下代码

  • //将上面代码的设置值部分进行修改

  • div.dataset.appId = 789;

  • div.dataset.myName = "secondname";

  • //最终结果


回答(2):

用data()方法。比如网页标签为

hehe

则jQuery中可以用 $("#hello").data("hello") 来获得 data-hello 中的值,也可以用 $("#hello").data("hello", "OK"); 来改变这个值

回答(3):

使用attr方法,attr() 方法设置或返回被选元素的属性值。
例如 $("被选元素").attr("data")

回答(4):

jquery获得元素data属性值的方法:

data-myid="3e4ae6c4e">Some awesome data


可是,怎么来读取这些数据呢?你当然可以遍历页面元素来读取你想要的属性,但jquery已经内置了方法来操作这些属性。使用jQuery的.data()方法来访问这些"data-*" 属性。其中一个方法就是 .data(obj),这个方法是在 jQuery1.4.3版本后出现的,它能返回相应的data属性。
举个例子,你可以用下面的写法读取 data-myid属性值:
var myid= jQuery("#awesome").data('myid');
console.log(myid);

你还可以在"data-*" 属性里使用json语法,例如,如果你写出下面的html:


你可以通过js直接访问这个数据,通过json的key值,你能得到相应的value:
var gameStatus= jQuery("#awesome-json").data('awesome').game;
console.log(gameStatus);

你也可以通过.data(key,value)方法直接给"data-*" 属性赋值。一个重要的你要注意的事情是,这些"data-*" 属性应该和它所在的元素有一定的关联,不要把它当成存放任意东西的存储工具。