Автозаполнение, появляющееся при вводе определенного символа
Подскажите, пожалуйста, по следующей проблеме.
Задача: необходимо реализовать появление формы автозаполнения в textarea, в том случае когда вводится определенный символ, например @. Нашел следующее решение: https://stackoverflow.com/questions/24533562/jquery-autocomplete-special-char-trigger/
$(function() {
var utilizatoriJson = [
{'label': "@ActionScript",'id':'1'},
{'label': "@Java",'id':'2'},
{'label': "@C++",'id':'3'},
{'label': "@Javascript",'id':'4'},
{'label': "@Python",'id':'5'},
{'label': "@BASIC",'id':'6'},
{'label': "@ColdFusion",'id':'7'},
{'label': "@Haskell",'id':'8'},
{'label': "@Lisp",'id':'9'},
{'label': "@Scala",'id':'10'}
];
function split( val ) {
return val.split( / \s*/ );
}
function extractLast( term ) {
return split( term ).pop();
}
$( "#tags" )
// don't navigate away from the field on tab when selecting an item
.bind( "keydown", function( event ) {
if ( event.keyCode === $.ui.keyCode.TAB &&
$( this ).autocomplete( "instance" ).menu.active ) {
event.preventDefault();
}
})
.autocomplete({
minLength: 1,
source: function( request, response ) {
// delegate back to autocomplete, but extract the last term
var lastword = extractLast(request.term);
if(lastword[0] != '@')
return false;
// Get all labels
var labels = utilizatoriJson.map(function(item){return item.label;});
response( $.ui.autocomplete.filter(
labels, lastword ) );
},
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;
}
});
});
<link rel="stylesheet" href="http://code.jquery.com/ui/1.11.0/themes/smoothness/jquery-ui.css">
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script>
<script src="//code.jquery.com/ui/1.11.0/jquery-ui.js"></script>
<div class="ui-widget">
<label for="tags">Tags: </label>
<input id="tags" size="50">
</div>
Подскажите, пожалуйста, как решить следующие проблемы:
- Как поменять input на textarea с сохраненим функционала.
- Если ввести @ и выбрать какой-либо вариант, а потом продолжить печатать, то выпадающий список с предыдущим вариантом продолжает быть виден, даже не вводя @. Как это убрать?
- Как сделать чтобы список начинал выпадать только когда вводишь @ и первую букву, а не сразу все варианты?
- Как ограничить число видимых вариантов в списке, например, до 5?
- Можно ли добавить в список вариантов поясняющий текст или сокращение к каждому варианту, наподобие: "@ActionScript" : "AS"?