是否有一种简单直接的方法来根据元素的数据属性选择元素?例如,选择所有具有customerID值为22的数据属性的锚。

我有点犹豫是否要使用rel或其他属性来存储此类信息,但我发现根据存储的数据选择元素要困难得多。


当前回答

为了在Chrome中工作,该值不能有另一对引号。

例如,它只能这样工作:

$('a[data-customerID=22]');

其他回答

只是用“生活标准”的一些特征来完成所有的答案-到目前为止(在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]

有时候,根据元素是否以编程方式(也就是不通过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属性data- customerid ==22的所有锚点,您应该包含a以将搜索范围限制为仅该元素类型。当页面上有许多元素时,在大循环中或高频执行数据属性搜索可能会导致性能问题。

$('a[data-customerID="22"]');

使用$('[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"]');

原生JS示例

获取元素的节点列表

var elem = document.querySelectorAll('[data-id="container"]')

Html: <div data-id="container"></div>

获取第一个元素

var firstElem = document.querySelector('[id="container"]')

Html: <div id="container"></div>

目标节点集合,该集合返回节点列表

document.getElementById('footer').querySelectorAll('[data-id]')

html:

<div class="footer">
    <div data-id="12"></div>
    <div data-id="22"></div>
</div>

根据多个(OR)数据值获取元素

document.querySelectorAll('[data-section="12"],[data-selection="20"]')

html:

<div data-selection="20"></div>
<div data-section="12"></div>

根据组合(AND)数据值获取元素

document.querySelectorAll('[data-prop1="12"][data-prop2="20"]')

html:

<div data-prop1="12" data-prop2="20"></div>

获取值开头的项

document.querySelectorAll('[href^="https://"]')