从数组中获取包含文本的元素

Get elements containing text from array

本文关键字:文本 元素 包含 获取 数组      更新时间:2023-09-26

我想搜索数组中包含任何字符串的所有元素。例如我有以下项目清单

<ul>
    <li>cricket bat</li>
    <li>tennis ball</li>
    <li>golf ball</li>
    <li>hockey stick</li>
</ul>

和这个阵列

var arr = ['bat', 'ball'];

它应该选择所有具有文本bat和ball的元素。如何使用jquery或javascript实现这一点。

这就是我尝试的

filter = 'bat ball';
var lis = row('UL li');
var flag = 0;
for (var i = 0; i < lis.length; i++) {
    var name = lis[i].getElementsByTagName('a')[0].innerHTML;
    if (name.toUpperCase().indexOf(filter) > -1) {
        flag = 1;
    } else {
        lis[i].style.display = 'none';
    }
}

您可以使用:contains伪选择器:

选择包含指定文本的所有元素。

$('li:contains("bat"), li:contains("ball")')

DEMO

您可以使用:包含选择器。

我想你指的是这些价值观中的任何一个,在这种情况下,

var arr = ['bat', 'ball'];
var selectors = arr.map(function(val) {
  return ':contains(' + val + ')'
});
var $lis = $('ul li').filter(selectors.join());
$lis.css('color', 'red')
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<ul>
  <li>cricket bat</li>
  <li>tennis ball</li>
  <li>golf ball</li>
  <li>hockey stick</li>
</ul>

试试这个:

$.each(["bat", "ball"], function (i,val) {
    if ($("ul li:contains(" + val + ")").length) {
        $("ul li:contains(" + val + ")").css('color', 'red')
    }
})

DEMO

尝试使用.filter().match()

var arr = ["bat", "ball"];
var res = Array.prototype.filter.call(document.querySelectorAll("li")
          , function(el, index) {
              return el.textContent.match(new RegExp(arr.join("|"))) !== null
          });
  
console.log(res);
<ul>
    <li>cricket bat</li>
    <li>tennis ball</li>
    <li>golf ball</li>
    <li>hockey stick</li>
</ul>