jQuery.suggest.js
这里的讨论导致了 jQuery 插件的开发,
你可以在这里找到:http://polarblau.github.com/suggest/。
因此,下面的所有代码和示例都已过时,但可能仍然存在
对某些人来说很有趣。
我一直对这个问题的结果非常感兴趣,但似乎还没有找到任何东西。
我已经考虑编写自己的解决方案一段时间了,我可以告诉你我的想法(这只是我现在的想法,绝对没有尝试过):
HTML:
<div id="search-container">
<input type="text" name="search" id="search" />
<input type="text" disabled="disabled" id="suggestion" />
</div>
CSS:
#container {
position: relative;
}
#search {
position: relative;
color: #000;
z-index: 10;
background: transparent;
// border, etc....
}
#suggestion {
position: absolute;
top: 0;
left: 0;
z-index: 0;
color: #ccc;
border: none;
// ...
}
使用 Javascript 'onkeydown' 匹配列表中的第一个(排序标准在这里很重要)单词,该单词在单词开头共享已键入的字母,并将其放在禁用的输入中字段#suggestion。如果用户点击回车,来自#suggestion 的单词将被传输到#search 输入字段,并且可能是提交的表单。
如果我有时间我会尝试把它变成一个可以工作的 jQuery 插件——让我们看看。但也许你明白了?
编辑
我已经尝试了我的想法,它似乎 work in it's simplest form 还可以。我很快会在我的github account 上将它作为一个小型 jQuery 插件发布。完成后,我会在此处给您留个便条。或者继续自己尝试一下,让我知道它是怎么来的。
这是我最终使用的代码(其中一部分可能是动态生成的):
HTML:
<div id="search-container">
<input type="text" name="search" id="search" />
<input type="text" disabled="disabled" id="suggestion" />
</div>
CSS:
* { margin: 0; padding: 0; }
#search-container {
position: relative;
}
#search-container input {
padding: 5px;
font-size: 1.2em;
width: 200px;
}
#search {
position: relative;
color: #000;
z-index: 10;
border: 1px solid #666;
background: transparent;
}
#suggestion {
position: absolute;
top: 0;
left: 0;
z-index: 0;
color: #ccc;
background: transparent;
border: 1px solid #fff;
}
JAVASCRIPT:
$(function() {
var haystack = [
"ActionScript",
"AppleScript",
"Asp",
"BASIC",
"C",
"C++",
"Clojure",
"COBOL",
"ColdFusion",
"Erlang",
"Fortran",
"Groovy",
"Haskell",
"Java",
"JavaScript",
"Lisp",
"Perl",
"PHP",
"Python",
"Ruby",
"Scala",
"Scheme"
];
$('#search').keyup(function(e) {
// 'enter' key was pressed
var $suggest = $('#suggestion');
var code = (e.keyCode ? e.keyCode : e.which);
if(code == 13) {
$(this).val($suggest.val());
$suggest.val("");
return false;
}
// some other key was pressed
var needle = $(this).val();
// is the field empty?
if (!$.trim(needle).length) {
$suggest.val("");
return false;
}
// compare input with haystack
$.each(haystack, function(i, term) {
var regex = new RegExp('^' + needle, 'i');
if (regex.test(term)) {
$suggest.val(needle + term.slice(needle.length));
// use first result
return false;
}
$suggest.val("");
});
});
});