提案されたものだけでなく、ユーザーが自分のバリアントを追加できるようにしたいと思います。しかし、フィールドに何かを入力して[Enter]をクリックすると、フォームが送信されます。
次に、フィールドのキーダウンイベントをキャッチしようとしましたが、この場合、UIパラメーターが定義されていないため、矢印を使用して提案からバリアントを選択し、キーを入力する可能性がありません。
$('#field_id').on('keydown', function(event) {
if (event.keyCode == $.ui.keyCode.ENTER
|| event.keyCode == $.ui.keyCode.NUMPAD_ENTER)
{
$('#field_id').trigger('autocompleteselect');
}
});
$('#field_id').autocomplete({
source: [{"id":"20","value":"This is not mandatory decline reason"},{"id":"21","value":"You are have to be rejected"}]
minLength: 0
}).on('autocompleteselect', function(event, ui) {
// if I click on suggestion using mouse - everything is ok
// but not for ENTER-key choosing
// I want something like that:
if (ui.item) {
id = ui.item.id;
value = ui.item.value;
} else {
id = 'my_new_item';
value = $(this).val();
}
return false;
});