从 attribute.dataset 和 jquery .data() 方法得到不同的结果

Getting different results from attribute.dataset and jquery .data() method

我得到了意想不到的结果,当我调试问题时,我发现我没有通过 Jquery .data() 获得正确的数据属性值方法。很明显,值不正确,当我将代码更改为 attribute.dataset.name(元素的原生 属性)时,它返回了预期值。

here's the screenshot of an error

任何想法,可能的原因是什么,因为我在我的情况下使用了很多数据属性并且不想在我通过 Jquery 访问数据属性的任何地方更改代码。 date() 方法。

.data(prop).dataset[prop] 可以不同,如果:

  • HTML 数据集包含一个值

  • jQuery 的 .data 之前已在元素上调用以存储与同一键关联的值

示例:

$('div').data('foo', 'newFooVal');

console.log($('div').data('foo'));
console.log($('div')[0].dataset.foo);
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div data-foo="oldFooVal"></div>

jQuery 的 .data 将检索:

  • 任何以前用 .data 设置的值(这将与数据集完全无关)

  • 如果没有为该元素的该键设置先前的值,将返回数据集中该键的值

所以你必须小心设置和检索。不可否认,它并不完全直观,因为它会在不同情况下做不同的事情。