首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >多个子级ul li标记中的html筛选器搜索

多个子级ul li标记中的html筛选器搜索
EN

Stack Overflow用户
提问于 2018-07-20 03:55:02
回答 2查看 160关注 0票数 0

我有以下代码,问题是当我搜索“Billy”时,我得到了所有三个"Billy",这是我所期望的。

然而,当我搜索"Bob“时,我只能得到两个父级"Bob”。为什么搜索循环只在每一层中搜索Bill而不是Bob?

现在,现在只有一个子列表,这将增加到许多。我想要的是在所有级别执行搜索

<input type="text" id="myInput" onkeyup="myFunction()" placeholder="Search for names.." title="Type in a name">

function myFunction() {
    var input, filter, ul, li, a, i;
    input = document.getElementById("myInput");
    filter = input.value.toUpperCase();
    ul = document.getElementById("myUL");
    li = ul.getElementsByTagName("li");
    for (i = 0; i < li.length; i++) {
        a = li[i].getElementsByTagName("a")[0];
        if (a.innerHTML.toUpperCase().indexOf(filter) > -1) {
            li[i].style.display = "";
        } else {
            li[i].style.display = "none";
        }
    }
}
<input type="text" id="myInput" onkeyup="myFunction()" placeholder="Search for names.." title="Type in a name">

<ul id="myUL">
  <li><a href="#">Billy</a></li>
  <li><a href="#">Bob</a></li>
  <li>
  	<ul>
    	<li><a href="#">Billy</a></li>
  		<li><a href="#">Bob</a></li>
    </ul>
  </li>
  <li><a href="#">Billy</a></li>
  <li><a href="#">Bob</a></li>

</ul>

EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51430792

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档