我正在使用此代码来搜索约500个li标签。用jQuery快速搜索大列表
$(function() {
$.expr[":"].containsInCaseSensitive = function(el, i, m){
var search = m[3];
if (!search) return false;
return eval("/" + search + "/i").test($(el).text());
};
$('#query').focus().keyup(function(e){
if(this.value.length > 0){
$('ul#abbreviations li').hide();
$('ul#abbreviations li:containsInCaseSensitive(' + this.value + ')').show();
} else {
$('ul#abbreviations li').show();
}
if(e.keyCode == 13) {
$(this).val('');
$('ul#abbreviations li').show();
}
});
});
这里是HTML:
<input type="text" id="query" value=""/>
<ul id="abbreviations">
<li>ABC<span>description</span></li>
<li>BCA<span>description</span></li>
<li>ADC<span>description</span></li>
</ul>
这个脚本是用这么多的李标签很慢。
我该如何加快速度,以及如何在li中搜索槽只有ABC文本,而不是span标签(不更改html)?
我知道现有的插件,但我需要一个像这样的小实现。
这里有兴趣的人
var abbrs = {};
$('ul#abbreviations li').each(function(i){
abbrs[this.firstChild.nodeValue] = i;
});
$('#query').focus().keyup(function(e){
if(this.value.length >= 2){
$('ul#abbreviations li').hide();
var filterBy = this.value.toUpperCase();
for (var abbr in abbrs) {
if (abbr.indexOf(filterBy) !== -1) {
var li = abbrs[abbr];
$('ul#abbreviations li:eq('+li+')').show();
}
}
} else {
$('ul#abbreviations li').show();
}
if(e.keyCode == 13) {
$(this).val('');
$('ul#abbreviations li').show();
}
});
+1正确的想法,但只有当li内部的值是唯一的时,这才能正确工作。你也正在做一个完全匹配。 – 2009-09-15 21:39:04
啊...部分匹配...嗯,我想添加所有首字母缩略词子串的排列将是一个丑陋的选择。 – 2009-09-15 22:18:59
代码中的一些错误,应该是:var abbrs = {}; \t $( 'UL#缩写立')每个(函数(I){ \t \t abbrs [this.firstChild.nodeValue] = I; \t})。 - 我怎样才能进行部分比赛? – 2009-09-16 18:33:48