2010-04-22 60 views
1

我遇到了一个我无法解决的问题。我在输入上使用jQuery的autocomplete插件。该HTML看起来是这样的:jQuery自动完成。不显示现有匹配

<tr id="row_house" class="no-display"> 
     <td class="col_num">4</td> 
     <td class="col_label">House Number</td> 
     <td class="col_data"> 
      <input type="text" title="House Number" name="house" id="house"/> 
      <button class="pretty_button ui-state-default ui-corner-all button-finish">Get house info</button> 
     </td> 
    </tr> 

我相信这是唯一id="house"领域。其他字段在此之前与自动完成工作正常,它基本上是相同的算法(其他变量,其他数据,其他调用)。那么为什么它不能像下面的init一样工作。代码:

$("#house").autocomplete(["1/4","6","6/1","6/4","8","8/1","8/5","10","10/1","10/3","10/4","12","12/1","12/5","12/6","14","14/1","15","15/1","15/2","15/4","15/5","16","16/1","16/2","16/21","16/2B","16/3","16/4","17","17/1","17/2","17/4","17/5","17/6","17/7","17/8","18","18/1","18/2","18/3","18/5","18/95","19","19/1","19/2","19/3","19/4","19/5","19/6","19/7","19/8","20","20/1","20/2","20/3","20/4","21","21/1","21/2","21/3","21/4","22","22/9","23","23/2","23/4","24","24/1","24/2","24/3","24/A","25","25/1","25/10","25/2","25/4","25/5","25/6","25/7","25/8","25/9","26","26/1","26/6","27","27/2","28","28/1","29","29/2","29/3","29/4","30","30/1","30/2","30/3","31","31/1","31/3","32/A","33","34","34/1","34/11","34/2","34/3","35","35/1","35/2","35/4","36","36/1","36/A","37","37/1","37/2","38","38/1","38/2","39/1","39/2","39/3","39/4","40","40/1","41","41/2","42","43","44","45","45/1","45/10","45/11","45/12","45/13","45/14","45/15","45/16","45/17","45/2","45/3","45/6","45/7","45/8","45/9","46","47","47/2","49","49/1","50","51","51/1","51/2","52","53","54","55/7","66","109","122","190/8","412"], {minChars:1, mustMatch:true}).result(function(event, result, formatted) { 
       var found=false; 
       for(var index=0; index<HChouses.length; index++) //HChouses is the same array used for init, but each entry is paired with a database ID. 
        if(HChouses[index][0]==result) 
        { 
         found=true; 
         HChouseId=HChouses[index][1]; 
         $("#row_house .button-finish").click(function() { 
          QueryServer("HouseConnect","FillData",true,HChouseId); //this performs an AJAX request 
         }); 
         break; 
        } 
       if(!found) 
        $("#row_house .button-finish").unbind("click"); 
      }); 

每次我开始打字(比如我按“1”键),文本显示和被立即删除。很少在重复按下后,我得到的名单(尽管比本应该短得多)alt text http://www.freeimagehosting.net/uploads/de3892134d.jpg

但如果在此之后,我按第二个数字,整个事情再次消失。 P.S.我使用Firefox 3.6.3进行开发。

+0

去尝试新的jQuery UI的插件,而不是,看看会是什么表现 http://jqueryui.com/demos/autocomplete/ – AlexanderMP 2010-04-22 13:25:29

+0

jQuery用户界面自动完成的作品,但不喜欢我想要的工作。它允许列表之外的值,不会通过突出显示匹配的序列来格式化数据。 还在等待这个问题的答案。 – AlexanderMP 2010-04-29 12:12:26

回答

1

看起来你所要求的是使用自动完成的文本框,当选择一个值时,它将执行一些函数(这里为QueryServer),其中包含所选值的ID。实际上,这是一个html <select>的动态版本。纠正我,如果这是错误的。

我最近用jQueryUI自动完成功能做了类似的事情。您在评论中提到,您已经尝试过这种方式,但没有运气,但我认为您对使用任一库的解决方案感兴趣。这是我会怎么做:

$("house").autocomplete({ 
    source: [{'id': 1, 'value': '10/1'}, {'id': 2, 'value': '10/3'}, {'id': 3, 'value': '10/4'}, .... 
    minLength: 1, 
    select: function(event, ui) { 
     //input will auto-populate with "value" part 
     $("#row_house .button-finish").click(function() { 
      QueryServer("HouseConnect","FillData",true,ui.item.id);       
     }); 
    }, 
    //this next function is a hack to replicate the "mustMatch" functionality of the bassistance autocomplete plugin 
    change: function (event, ui) { 
     var source = $(this).val(); 
     var found = $('.ui-autocomplete li').text().search(source); 
     if(found < 0) { //no match! 
      $(this).val(''); 
      $("#row_house .button-finish").unbind("click"); 
     }    
    } 
}); 

您可能要到别处声明source值,使它有点整洁。

希望有帮助!

+0

非常感谢您的回复。我确实找到了传递对象的功能,而不是简单的字符串来传递自动完成的源代码。现在没有时间回到那个序列并且做对了。我为什么选择自动完成插件而不是UI功能的主要两个原因是文本被突出显示以指示字符串中的匹配,以及我只能强制执行严格匹配的事实,而UI功能确实接受任何字符串。 – AlexanderMP 2010-05-06 07:46:09

+0

这样做是为了让用户可以使用自动完成功能从数据库中选择房屋而不是选择(选择框太多房屋),并且当选择一个值时,数据库中存在该值,选择得到一个通过AJAX获取房屋信息的功能。 – AlexanderMP 2010-05-06 08:01:06

+0

我交给我的例子中的autocomplete()函数的'change'参数复制插件的mustMatch功能 - 只强制严格匹配。 但请记住,无论您选择使用哪个库,它们都是服务器端JavaScript。用户可以简单地选择禁用JavaScript并将他们喜欢的任何数据提交给服务器。 虽然突出文字是一个公平点。 – majackson 2010-05-06 09:18:19