我正在使用来自 jquery-ui 的自动完成功能。在多个值中,您可以在空格后获取每个单词的下拉列表,但下拉列表显示为输入框的大小。是否可以使下拉菜单出现在每个宽度等于下拉单词而不是输入框的整个长度的光标下方?
编辑:示例(类似 Google 的搜索框):
当您进入谷歌并随着句子的继续输入一个长句子时,在每个单词之后,光标位置下方的每个单词都会出现一个自动完成下拉菜单。所以我需要一个类似的下拉菜单,可以添加到 jQuery Autocomplete
我的功能这么大,因为它具有多个单词和按字母顺序显示数组的功能。这是<script
代码:
<script>
$(function() {
var availableTags = <?php echo json_encode($sometags); ?>;
function split( val ) {
return val.split( / \s*/ );
}
function extractLast( term ) {
return split( term ).pop();
}
$( "#query" )
// don't navigate away from the field on tab when selecting an item
.bind( "keydown", function( event ) {
if ( event.keyCode === $.ui.keyCode.TAB &&
$( this ).data( "autocomplete" ).menu.active ) {
event.preventDefault();
}
})
.autocomplete({
minLength: 1,
source: function( request, response ) {
// delegate back to autocomplete, but extract the last term
response( $.ui.autocomplete.filter(
availableTags, extractLast( request.term ) ) );
var term = $.ui.autocomplete.escapeRegex(request.term)
, startsWithMatcher = new RegExp("^" + term, "i")
, startsWith = $.grep(availableTags, function(value) {
return startsWithMatcher.test(value.label || value.value || value);
})
, containsMatcher = new RegExp(term, "i")
, contains = $.grep(availableTags, function (value) {
return $.inArray(value, startsWith) < 0 &&
containsMatcher.test(value.label || value.value || value);
});
response(startsWith.concat(contains));
},
focus: function() {
// prevent value inserted on focus
return false;
},
select: function( event, ui ) {
var terms = split( this.value );
// remove the current input
terms.pop();
// add the selected item
terms.push( ui.item.value );
// add placeholder to get the comma-and-space at the end
terms.push( "" );
this.value = terms.join( " " );
return false;
}
});
});
</script>
编辑:就像谷歌框一样,下拉菜单应该包含在输入框的宽度内,例如,输入框中最后一个单词的下拉框应该调整大小而不是向右而是向左。下拉框的右边缘应与输入框的右边缘对齐,并且下拉框的总宽度(如果单词与输入框一样大或大于输入框)不应超过输入框的宽度。
更新:
这是类似 google 的自动完成功能的最终模式:Fiddle(2013 年 16 月 2 日更新)
特点:
1)修复了多个单词按字母顺序对建议进行排序(jQuery-ui 自动完成多个值按字母顺序排序结果)
2)从2 个数组,第一个建议在输入框的全宽处打开,如在谷歌中,其余建议在最长建议的宽度处
3) 修复了在“空格”之后输入单词之前下拉打开的错误(多个值)。
4)防止下拉菜单在末尾保持打开状态,同时在其间添加单词。
5) 16/2/2013 更新:当从建议框输入的标签长度超过输入框长度时,输入下一个标签时,输入框从第一个标签显示或移回第一个标签位置,不是从此处看到的光标最后放置的位置 - http://jqueryui.com/autocomplete/#multiple。这已得到修复。
这是一个类似的小提琴,只使用一个数组,建议总是在最长建议的宽度 - FIDDLE
感谢 Jeffery To 提供了该问题的主要解决方案,感谢 Vadim 和 Dom,他们的回答提供了对创建上述 mod 有用的想法。