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