将自定义函数添加到bootstrap typeahead

时间:2012-12-19 20:22:48

标签: javascript jquery twitter-bootstrap bootstrap-typeahead typeahead

我使用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
 });

1 个答案:

答案 0 :(得分:1)

您可以将函数绑定到用户字段的blur事件。因此,一旦用户对另一个表单元素进行任何更改(如果它保留为空白),则清除typeahead字段。

$('#user-field').blur(function (e) {
   if(this.val() === ''){
        $('#typeahead-field').val(''); // Clear typeahead
   }
});