У меня есть jqgrid, который использует автозаполнение jQueryUI в столбце. Все работает отлично, за исключением одной мелочи, если пользователь выберет «fsdfsdfsfasf» и нажмете «Enter», моя программа, конечно, взбесится и скажет, что такого элемента не существует.
Я хочу сделать некоторую проверку, поэтому, если пользователь вводит некоторые данные, которых нет в списке автозаполнения, программа автоматически помещает текст автозаполнения в ""
, как здесь: http://view.jquery.com/trunk/plugins/autocomplete/demo/ в поле "месяц".
Поскольку я использую автозаполнение jQueryUI, а не автозаполнение jquery, я не могу использовать опцию mustmatch
.
{
name: 'Brand',
index: 'Brand',
align: 'left',
width: 50,
sortable: true,
editable: true,
edittype: 'text',
editoptions: {
dataInit:
function (elem) {
$(elem).autocomplete({
delay: 0,
minLength: 0,
source: '@Url.Action("GetBrands")',
minChars: 0,
max: 12,
autoFill: true,
mustMatch: true,
matchContains: false,
scrollHeight: 220,
formatItem: function(data, i, total) {
return data[0];
},
select: function (event, ui) {
if (ui.item.value == "Opret ny Brand...") {
$(function () {
var dialogDiv = $('#dialog');
var viewUrl = '@Url.Action("CreateBrand")';
$.get(viewUrl, function (data) {
dialogDiv.html(data);
var $form = $("#updateCarForm");
$form.unbind();
$form.data("validator", null);
//Check document for changes
$.validator.unobtrusive.parse(document);
//Re add validation with changes
$form.validate($form.data("unobtrusiveValidation").options);
//open dialog
dialogDiv.dialog('open');
});
});
}
}
})
.data("autocomplete")._renderItem = function (ul, item) {
return $("<li></li>")
.data("item.autocomplete", item)
.append("<a><span style='display:inline-block;width:60px;'><b>" +
item.value + "</b></span></a>")
.appendTo(ul);
};
}
}
},