是否有一种简单直接的方法来根据元素的数据属性选择元素?例如,选择所有具有customerID值为22的数据属性的锚。
我有点犹豫是否要使用rel或其他属性来存储此类信息,但我发现根据存储的数据选择元素要困难得多。
是否有一种简单直接的方法来根据元素的数据属性选择元素?例如,选择所有具有customerID值为22的数据属性的锚。
我有点犹豫是否要使用rel或其他属性来存储此类信息,但我发现根据存储的数据选择元素要困难得多。
当前回答
只是用“生活标准”的一些特征来完成所有的答案-到目前为止(在html5时代),没有第三方libs是可能做到的:
纯/纯JS与querySelector(使用css选择器): select document.querySelector('[data-answer="42"],[type="submit"]') select所有DOM: document.querySelectorAll('[data-answer="42"],[type="submit"]') 纯/纯CSS 一些特定的标签:[data-answer="42"],[type="submit"] 所有具有特定属性的标签:[data-answer]或input[type]
其他回答
只是用“生活标准”的一些特征来完成所有的答案-到目前为止(在html5时代),没有第三方libs是可能做到的:
纯/纯JS与querySelector(使用css选择器): select document.querySelector('[data-answer="42"],[type="submit"]') select所有DOM: document.querySelectorAll('[data-answer="42"],[type="submit"]') 纯/纯CSS 一些特定的标签:[data-answer="42"],[type="submit"] 所有具有特定属性的标签:[data-answer]或input[type]
像这样的结构:$('[data-XXX=111]')在Safari 8.0中不起作用。
如果你这样设置数据属性:$('div')。data('XXX', 111),如果你直接在DOM中设置数据属性,它只会起作用:$('div')。attr(“data-XXX”,111)。
我认为这是因为jQuery团队优化了垃圾收集器,以防止内存泄漏和对每个更改数据属性的DOM重建的繁重操作。
要选择具有data属性data- customerid ==22的所有锚点,您应该包含a以将搜索范围限制为仅该元素类型。当页面上有许多元素时,在大循环中或高频执行数据属性搜索可能会导致性能问题。
$('a[data-customerID="22"]');
有时候,根据元素是否以编程方式(也就是不通过dom-attributes)附加数据项来过滤元素是可取的:
$el.filter(function(i, x) { return $(x).data('foo-bar'); }).doSomething();
上面的内容有用,但可读性不强。一个更好的方法是使用伪选择器来测试这类事情:
$.expr[":"].hasData = $.expr.createPseudo(function (arg) {
return function (domEl) {
var $el = $(domEl);
return $el.is("[" + ((arg.startsWith("data-") ? "" : "data-") + arg) + "]") || typeof ($el.data(arg)) !== "undefined";
};
});
现在,我们可以将原始语句重构为更流畅和可读的内容:
$el.filter(":hasData('foo-bar')").doSomething();
使用$('[data-whatever="myvalue"]')将选择任何带有html属性的东西,但在更新的jQueries中,似乎如果你使用$(…).data(…)来附加数据,它使用了一些神奇的浏览器东西,并且不影响html,因此不会被.find发现,如前面的答案所示。
验证(1.7.2+测试)(另见fiddle):(更新更完整)
var $container = $('<div><div id="item1"/><div id="item2"/></div>');
// add html attribute
var $item1 = $('#item1').attr('data-generated', true);
// add as data
var $item2 = $('#item2').data('generated', true);
// create item, add data attribute via jquery
var $item3 = $('<div />', {id: 'item3', data: { generated: 'true' }, text: 'Item 3' });
$container.append($item3);
// create item, "manually" add data attribute
var $item4 = $('<div id="item4" data-generated="true">Item 4</div>');
$container.append($item4);
// only returns $item1 and $item4
var $result = $container.find('[data-generated="true"]');