0
我遵循另一個問題的建議,但它不適用於我。我正在使用JQuery 1.8.3和JQuery UI 1.9.2如何使用JQuery UI創建一個自動完成SlickGrid編輯器1.9.2
當我按箭頭鍵時,自動完成不會選擇下一個選項。爲什麼?
我試過每個事件處理函數stopPropagation。我使用了按鍵,鍵盤,鍵盤,處理程序。我甚至將我的輸入元素封裝在父標記中,並將stopPropagation放置在這些事件上,而箭頭鍵仍然不適用於autocomplete元素。他們只是試圖改變驗證器功能所阻止的單元。
$input.bind("keydown.nav", function (e) {function AutoCompleteEditor(args) {
var $input,
defaultValue,
scope = this;
this.init = function() {
$input = $("<INPUT type=text class='editor-text' />");
$input.appendTo(args.container)
.focus()
.select()
.autocomplete({
delay: 0,
minLength: 0,
source: args.column.options
})
.bind("keydown.nav", function (e) {
if (e.keyCode === $.ui.keyCode.LEFT || e.keyCode === $.ui.keyCode.RIGHT) {
e.stopImmediatePropagation();
e.stopPropagation();
} else if (e.keyCode === $.ui.keyCode.UP || e.keyCode === $.ui.keyCode.DOWN) {
e.stopImmediatePropagation();
e.stopPropagation();
}
})
};
this.destroy = function() {
$input.autocomplete('destroy');
$input.remove();
};
this.focus = function() {
$input.focus();
};
this.getValue = function() {
return $input.val();
};
this.setValue = function (val) {
$input.val(val);
};
this.loadValue = function (item) {
defaultValue = item[args.column.field] || "";
$input.val(defaultValue);
$input[0].defaultValue = defaultValue;
$input.select();
};
this.serializeValue = function() {
return $input.val();
};
this.applyValue = function (item, state) {
item[args.column.field] = state;
};
this.isValueChanged = function() {
return (!($input.val() == "" && defaultValue == null)) && ($input.val() != defaultValue);
};
this.validate = function() {
var val = $input.val();
return {
valid: args.column.options.indexOf(val) > -1,
msg: null
};
};
this.init();
}
請注意,我**沒有**在任何地方使用'.bind(「keydown.nav」)'。我認爲將整個編輯器代碼放入「綁定」調用中並不是一個好主意!我建議分開一件事。 –
這是行不通的。箭頭鍵從不會將其添加到自動填充小部件,因此您無法選擇任何建議。 無論你將事件綁定到什麼地方,停止傳播都不起作用。 –