email 自动补全 兼容主流浏览器

/**
* Email-自动完成组件
* box 装载数组的容器,位于绑定的input下侧
* inputId 需要绑定的input对象的id 【必选】
* souce Array ['163.com','sina.com','126.com','139.com'] 【必选】
* dataList 放在box中的数组
* 使用方法如下:
* var emailArray = ["163.com", "126.com", "qq.com", "sina.com", "vip.sina.com", "hotmail.com", "gmail.com", "sina.cn", "suho.com", "yahoo.cn", "139.com", "wo.com.cn", "189.cn"];
* autocomplete.init("需绑定对象的id值", emailArray);
* 需要引用 jquery.js
*/

var autocomplete = {
box: null,
inputObj: null,
inputId: null,
souce: [],
dataList: [],
init: function(inputId, souce) {
this.souce = souce;
inputObj = $("#" + inputId),
that = this;
inputObj.live("focus",
function() {
autocomplete.box.style.display = "block";
});
inputObj.live("input propertychange",
function() {
that.changeEvent()
});
inputObj.live("blur",
function() {
that.focusout()
});
this.createDiv(inputObj);
this.box.style.top = inputObj.offsetTop + inputObj.offsetHeight + "px";
this.box.style.left = inputObj.offsetLeft + "px";
},
changeEvent: function() {
var str = inputObj.val();
if (str.indexOf("@") == -1) {
for (var i = 0; i < autocomplete.dataList.length; i++) {
autocomplete.dataList[i].innerHTML = str + "@" + autocomplete.souce[i];
}
}
},
focusout: function() {
setTimeout(function() {
autocomplete.box.style.display = "none";
},
400)
},
createDiv: function(inputObj) {
this.box = document.createElement("div");
inputObj.after(this.box);
var ulObj = document.createElement("ul");
this.box.appendChild(ulObj);
for (var i = 0; i < this.souce.length; i++) {
var liObj = document.createElement("li");
this.addEvent(liObj, "click",
function() {
if (inputObj.val() != "") {
inputObj.val(liObj.innerHTML)
} else {
alert("请输入邮箱!")
}
});
liObj.innerHTML = this.souce[i];
this.dataList.push(liObj);
ulObj.appendChild(liObj);
}
this.box.style.display = "none";
},
addEvent: function(obj, type, fn) {
if (obj.addEventListener) {
obj.addEventListener(type, fn, false);
} else if (obj.attachEvent) {
obj.attachEvent("on" + type, fn);
}
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值