如何使用Twitter的bootstrap typeahead实现电子邮件自动完成?

时间:2012-04-11 18:53:47

标签: javascript jquery email twitter-bootstrap typeahead

即。如何修改Twitter's bootstrap typeahead代码以忽略符号@之前的所有内容?因此,当用户输入电子邮件时,一旦输入@,我们应该从预定义列表(如gmail.com,yahoo.com,att.net等)为他建议域名。

2 个答案:

答案 0 :(得分:1)

不,如果没有额外的魔力,你就无法做到。幸运的是,这种魔力非常简单有趣。我非常喜欢解决这个难题:)

考虑一下我创建的example

$.fn.typeahead.Constructor.prototype.select = function() {
    var val = this.$menu.find('.active').attr('data-value'),
        newVal = this.$element.val().replace(/@.*$/, '@' + val);
    this.$element.val(newVal);
    this.$element.change();
    return this.hide();
};

$('#email').typeahead({
    source: ['gmail', 'hotmail', 'yahoo'],
    matcher: function(item) {
        var m = this.query.indexOf('@'),
            search;

        if (!~m) {
            return false;
        }

        search = this.query.substr(m + 1).toLowerCase();
        return search.length && ~item.toLowerCase().indexOf(search);
    }
});

首先,您需要定义自定义matcher函数,以便定义哪些值被认为是合适的。这很容易。复杂的部分是你需要更改Typeahead原型以使插件设置输入字段的正确新值:例如不是gmail,' yahoo',而是完整的电子邮件地址,如tomas@gmail.com等。

答案 1 :(得分:0)

实际上我们不需要做一些扩展,只需使用像这样的ajax函数。

$('.typeahead').typeahead({
    source: function (typeahead, query) {

     var con = $('#input1').val();
     var atpos = con.indexOf('@');
     if(atpos==-1){
        return [con+'@gmail.com',con+'@sina.com',con+'@qq.com',con+'@126.com'];
     }else if(atpos>0){
         //get value before @
         var tmp = con.substr(0,atpos);
         return [tmp+'@gmail.com',tmp+'@sina.com',tmp+'@qq.com',tmp+'@126.com'];
     }else{

     }
     //return ['alpha','beta','bravo','delta','epsilon','gamma','zulu'];
    }
});