国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

用javascript模仿ie的自動完成類似自動完成功的表單

2024-05-06 14:20:37
字體:
來源:轉載
供稿:網友
最近在寫一個javascript框架,看見網上有不少自動完成功能的表單,所以一時興起,用javascript寫了一個,為自己的框架增點色.

步驟:
1.傳入兩個參數,第一個是你要綁定的表單對象,第二個是你要檢索的數組.
2.動態建立一個div做為你要自動完成的層,設置屬性和事件(我在這里并沒有設置div的visible和display屬性,而是將它的left設為"-1000px",這樣就移出了瀏覽器之外,達到了隱藏的效果.
3.對傳入的數組進行檢索,找出與輸入內容匹配或相近的項,并將其存入一個新的數組.這里用正則表達式進行了四次迭代,寫的不好,還望見諒.
4.對存入檢索后數據的那個新數組進行處理,去掉內容重復的項,并將其寫進div內.
5.設置div的left,top,width即可.

下面看給出的完整代碼:
代碼如下:
if(!sx)
var sx={};
sx.activex={};
sx.activex.autocomplete={
bind:function(a,s){
var d=document.createElement("div");
d.style.position="absolute";
d.flag="autocomplete";
document.body.appendChild(d);
d.style.left="-1000px";
d.style.height="100px";
d.style.overflow="auto";
a.onblur=function(){
if(document.elementFromPoint(window.event.clientX,window.event.clientY).flag=="autocomplete" || document.elementFromPoint(window.event.clientX,window.event.clientY).parentNode.flag=="autocomplete")
return;
d.innerHTML="";
d.style.left="-1000px";
}
a.onkeyup=function(){
if(a.value=="") {
d.innerHTML="";
return;
}
d.innerHTML="";
var t=[];
for(var i in s){
if(eval("/^"+a.value+"$/i").test(s[i])){
t.push(s[i]);
}
}
for(var i in s){
if(eval("/^"+a.value+".+$/i").test(s[i])){
t.push(s[i]);
}
}
for(var i in s){
if(eval("/^.+"+a.value+"$/i").test(s[i])){
t.push(s[i]);
}
}
for(var i in s){
if(eval("/^.+"+a.value+".+$/i").test(s[i])){
t.push(s[i]);
}
}
for(var e=0;e<=t.length-2;e++){
for(var e1=e+1;e1<=t.length-1;e1++){
if(t[e]==t[e1]){
for(var e2=e1+1;e2<t.length;e2++){
if(t[e2]){
t[e2-1]=t[e2];
}
}
t.length=t.length-1;
}
}
}
//alert(t);
for(var i in t){
var p=document.createElement("div");
p.innerText=t[i];
p.onmouseenter=function(){
this.style.backgroundColor="blue";
}
p.onmouseleave=function(){
this.style.backgroundColor="white";
}
p.onclick=function(){
a.value=this.innerText;
d.style.left="-1000px";
}
d.appendChild(p)
}
d.style.top=a.offsetTop+a.offsetHeight+"px";
d.style.left=a.offsetLeft+"px";
d.style.width=a.offsetWidth+"px";
}
}
}.

調用的html代碼:
代碼如下:
<html>
<head>
<title>Untitled Document</title>
</head>
<body>
<script src="kongjian.js"></script>
<input type="text" size="15" id="a">
<input type="text" size="15" id="a1">
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 德惠市| 兴隆县| 万安县| 内黄县| 博湖县| 大邑县| 嘉定区| 泉州市| 霍州市| 吉木萨尔县| 凤凰县| 和田市| 格尔木市| 梓潼县| 临澧县| 那坡县| 平顺县| 偏关县| 潮州市| 马龙县| 营山县| 宜城市| 徐汇区| 安康市| 洛隆县| 垦利县| 喀什市| 淄博市| 兴仁县| 油尖旺区| 荣成市| 宣威市| 和硕县| 荃湾区| 阳东县| 横峰县| 万全县| 瑞丽市| 乐安县| 天柱县| 水富县|