在输入字段上敲了一个简单的建议框..到目前为止,除了我似乎无法解决的两个问题外,所有工作都正常:
1) 当 onkeypress 事件触发时,输入框的值不正确 - 它错过了最后一个字符!因此,例如,如果您输入 3 个字符,则只有前两个字符会通过。所以有时建议并不完全准确!
2)我需要注意用户按下箭头键,然后将焦点设置到建议框中的第一个列表项!但似乎无法让它工作!
已包含代码供您查看!欢迎任何建议.. 但是我真的不想使用插件,因为我已经完成了这 95%..
这是jsfiddle链接! http://jsfiddle.net/beardedSi/kr4Cq/
注意 - 我刚刚注意到,在小提琴版本中,因为我在代码中放置了虚拟数组,它不再匹配建议 - 但这没关系,它在我的工作代码中工作正常!
work = true;
function finish() {
work = true;
}
var autoComp = $('.autoComp');
var skillInput = $('.new-skills input');
$('.new-skills input').keypress(function (e) {
var param = $(skillInput).val();
if (param.length > 0) {
$.getJSON('/recruiter/home/GetAutocompleteSkills?term=' + param, function (data) {
$(autoComp).slideDown().empty();
var items = [];
$.each(data, function (key, val) {
items.push('<li><a href="">' + val + '</a></li>');
});
$(autoComp).append(items.join(''));
$('.base-wrapper a').not('.button').click(function (e) {
work = false;
e.preventDefault();
$(skillInput).val($(this).text());
$(autoComp).empty().slideUp(500, finish);
});
});
}
});
$(skillInput).keydown(function (e) {
if (e.keyCode == 40) {
console.log("down");
$('.autoComp li:first:child').focus();
}
});
$('.new-skills input').blur(function () {
if (work == true)
$(autoComp).slideUp();
});