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

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


当前回答

要选择具有data属性data- customerid ==22的所有锚点,您应该包含a以将搜索范围限制为仅该元素类型。当页面上有许多元素时,在大循环中或高频执行数据属性搜索可能会导致性能问题。

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

其他回答

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

您应该可以省略*,但如果我没记错的话,这可能会给出错误的结果,这取决于您使用的jQuery版本。

注意,为了与selector API (document.querySelector{,all})兼容,在这种情况下不能省略属性值(22)周围的引号。

另外,如果你经常在jQuery脚本中使用数据属性,你可能会考虑使用HTML5自定义数据属性插件。这允许您通过使用. dataattr ('foo')编写更可读的代码,并导致缩小后的文件大小更小(与使用.attr('data-foo')相比)。

要选择具有data属性data- customerid ==22的所有锚点,您应该包含a以将搜索范围限制为仅该元素类型。当页面上有许多元素时,在大循环中或高频执行数据属性搜索可能会导致性能问题。

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

像这样的结构:$('[data-XXX=111]')在Safari 8.0中不起作用。

如果你这样设置数据属性:$('div')。data('XXX', 111),如果你直接在DOM中设置数据属性,它只会起作用:$('div')。attr(“data-XXX”,111)。

我认为这是因为jQuery团队优化了垃圾收集器,以防止内存泄漏和对每个更改数据属性的DOM重建的繁重操作。

通过Jquery filter()方法:

http://jsfiddle.net/9n4e1agn/1/

HTML:

<button   data-id='1'>One</button>
<button   data-id='2'>Two</button>

JavaScript:

$(function() {    
    $('button').filter(function(){
        return $(this).data("id")   == 2}).css({background:'red'});  
     });

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