根据数据集规范,element.dataset是如何删除数据属性的?考虑:
<p id="example" data-a="string a" data-b="string b"></p>
如果你这样做:
var elem = document.querySelector('#example');
elem.dataset.a = null;
elem.dataset.b = undefined;
elem.dataset.c = false;
elem.dataset.d = 3;
elem.dataset.e = [1, 2, 3];
elem.dataset.f = {prop: 'value'};
elem.dataset.g = JSON.stringify({prop: 'value'});
DOM 在 Chrome 和 Firefox 中变成这样:
<p id="example"
data-a="null"
data-b="undefined"
data-c="false"
data-d="3"
data-e="1,2,3"
data.f="[object Object]"
data.g="{"prop":"value"}"
></p>
Chrome/Firefox 实现模仿setAttribute。它基本上.toString()
首先适用。除了处理之外,这对我来说很有意义,null
因为我希望这null
会删除该属性。否则,数据集 API 如何等效于:
elem.removeAttribute('data-a');
那么布尔属性呢:
<p data-something>
相当于<p data-something="">
嗯。