是否有一种简单直接的方法来根据元素的数据属性选择元素?例如,选择所有具有customerID值为22的数据属性的锚。
我有点犹豫是否要使用rel或其他属性来存储此类信息,但我发现根据存储的数据选择元素要困难得多。
是否有一种简单直接的方法来根据元素的数据属性选择元素?例如,选择所有具有customerID值为22的数据属性的锚。
我有点犹豫是否要使用rel或其他属性来存储此类信息,但我发现根据存储的数据选择元素要困难得多。
当前回答
为了在Chrome中工作,该值不能有另一对引号。
例如,它只能这样工作:
$('a[data-customerID=22]');
其他回答
它会工作的:)
$('.ic-star[data-rate=“1”]').addClass('rated');
$('*[data-customerID="22"]');
您应该可以省略*,但如果我没记错的话,这可能会给出错误的结果,这取决于您使用的jQuery版本。
注意,为了与selector API (document.querySelector{,all})兼容,在这种情况下不能省略属性值(22)周围的引号。
另外,如果你经常在jQuery脚本中使用数据属性,你可能会考虑使用HTML5自定义数据属性插件。这允许您通过使用. dataattr ('foo')编写更可读的代码,并导致缩小后的文件大小更小(与使用.attr('data-foo')相比)。
我还没见过没有jQuery的JavaScript答案。希望它能帮助到某些人。
var elements = document.querySelectorAll('[data-customerID="22"]'); 元素[0]。innerHTML = '它工作了!'; 测试< data-customerID = ' 22 ' > < / >
信息:
数据属性 .querySelectorAll ();
使用$('[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"]');
要选择具有data属性data- customerid ==22的所有锚点,您应该包含a以将搜索范围限制为仅该元素类型。当页面上有许多元素时,在大循环中或高频执行数据属性搜索可能会导致性能问题。
$('a[data-customerID="22"]');