JQuery中的活动搜索栏

时间:2015-04-08 15:25:29

标签: javascript jquery html list search

我正在尝试为项目列表创建搜索选项。这样,用户可以搜索列表中的特定项目。但是,我有几个问题。我的列表同时使用span和images。我创建的jquery排序按范围对列表进行排序就好了,但是当我尝试使用主动搜索时它没有做任何事情。这是我的示例代码:

<input type="text" name="searchList" id="searchInput" placeholder="Type Here To Search" />
<ul id="lessonList" class="lessonlist">
<li><span class="name">Lesson 1</span>
    <img src="images/lessonFiller1.png" width="45%" height="45%"/>
</li>
<li><span class="name">Lesson 2</span>
    <img src="images/lessonFiller2.png" width="45%" height="45%"/></li>
<li><span class="name">Lesson3</span>
    <img src="images/lessonFiller3.png" width="45%" height="45%" /></li>
<li><span class="name">Lesson 4</span>
    <img src="images/lessonFiller4.png" width="45%" height="45%"/></li>
<li><span class="name">Lesson 5</span>
    <img src="images/lessonFiller5.png" width="45%" height="45%"/></li>
</ul>

再次,我的排序jQuery工作正常:

$(document).ready(function(e) {
var desc = $(this).hasClass("asc"),
    list = $("#lessonList");
list.append(list.children().get().sort(function(a, b) {
    var aProp = $(a).find("span.name").text(),
        bProp = $(b).find("span.name").text();
    return (aProp > bProp ? 1 : aProp < bProp ? -1 : 0) * (desc ? -1 : 1);
}));
$(this).toggleClass("desc", desc)
       .toggleClass("asc", !desc)
       .siblings().removeClass("asc desc");
e.preventDefault();});

但是,当我尝试使用输入创建活动搜索时,没有任何反应。这是它的代码:

$('#searchInput').keyup(function(){

//var that = this, $allListElements = $('ul > li');
var valThis = $(this).val();
var list = $('ul li span');

list.each(function(){
 var text = $(this).text().toLowerCase();
    (text.indexOf(valThis) == 0) ? $(this).show() : $(this).hide();});});

我做错了什么?这甚至是我可以做的事情吗?提前谢谢。

1 个答案:

答案 0 :(得分:0)

有多个问题,

  1. 你在哪里包括你的剧本?在头部或最后一个体内?如果在创建html dom元素之前加载脚本,则将你的keyup绑定放在ready函数中。
  2. 隐藏li不跨越。使用parent()显示/隐藏。
  3. 下面的代码应该有用,链接是https://jsfiddle.net/4pbp5dhr/

    $(document).ready(function(e) {
     var desc = $(this).hasClass("asc"),
    list = $("#lessonList");
    list.append(list.children().get().sort(function(a, b) {
    var aProp = $(a).find("span.name").text(),
        bProp = $(b).find("span.name").text();
        return (aProp > bProp ? 1 : aProp < bProp ? -1 : 0) * (desc ? -1 : 1);
    }));
    $(this).toggleClass("desc", desc)
       .toggleClass("asc", !desc)
       .siblings().removeClass("asc desc");
     //e.preventDefault();
    
    //Move the search input inside ready
    $('#searchInput').keyup(function(){
    
    //var that = this, $allListElements = $('ul > li');
    var valThis = $(this).val();
    console.log(valThis);
    var list = $('ul li span');
    
    list.each(function(){
       var text = $(this).text().toLowerCase();
       (text.indexOf(valThis) == 0) ? $(this).parent().show() :      $(this).parent().hide();});
    });
    
    });
    

    我评论了preventDefault()。