我使用typeahead来提取名称,然后使用与名称相对应的id更新隐藏字段。在我的表单中,名称可以留空,填写它不是必需的。
有没有办法将自定义错误检查添加到预先输入功能?例如,我开始填写表单并输入/选择一个用户,然后我改变主意并希望将其留空。到目前为止,用户ID已经添加到隐藏字段中,因此即使我将名称字段留空,表单也会以其中的用户ID传递。
我想我总是可以对提交进行错误检查,但我很好奇是否有办法添加到原生api。
我的代码是:
$('#name_field').typeahead({
minLength: 3,
source: function (query, process){
$.get('/url/getsource', {query: query}, function (data) {
names = [];
map = {};
$.each(data, function (i, name) {
map[name.uName] = name;
names.push(name.uName);
});
process(names);
});
},
matcher: function (item) {
if (item.toLowerCase().indexOf(this.query.trim().toLowerCase()) != -1) {
return true;
}
},
sorter: function (items) {
return items.sort();
},
highlighter: function (item) {
var regex = new RegExp( '(' + this.query + ')', 'gi' );
return item.replace( regex, "<strong>$1</strong>" );
},
updater: function (item) {
selectedID = map[item].id;
$('#id_field').val(selectedID);
return item;
}
});
我希望我可以添加类似
的内容$('#name_field').typeahead({
myCustom: function (){
if($('#name_field').val() == ''){
$('#id_field').val('');
},
rest,
of the,
function
});
答案 0 :(得分:1)
您可以将函数绑定到用户字段的blur事件。因此,一旦用户对另一个表单元素进行任何更改(如果它保留为空白),则清除typeahead字段。
$('#user-field').blur(function (e) {
if(this.val() === ''){
$('#typeahead-field').val(''); // Clear typeahead
}
});