asp: suggest ajax

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
 
<head>
<meta content="text/html; charset=utf-8" http-equiv="Content-Type" />
<title>suggest ajax示例</title>
<meta name="author" content="geovindu 塗聚文"/><style type="text/css">
.ajaxsearch { 
 width:300px; /*提示层的宽度 */
</style>
<script language="javascript" src="suggestajax.js" type="text/javascript"></script>
 
</head>
  
<body onResize="removediv();">
<div style="margin:20px 50px">
<input style="width:298px;height:18px" type="text" autocomplete="off" onBlur="blurdeal();" onKeyDown="keydowndeal(event);" onFocus="focusdeal(event);" />
</div>
</body>
 
</html>

 suggestajax.js:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
///////////////////////////////搜索提示框///////////////////////////////// 
var obj_div;     //提示层对象 
var obj_input;     //输入框对象 
var main_delay;     //判断值变化延迟对象 
var ajax_delay;     //ajax延迟搜索对象 
var updown_delay;    //方向键延迟对象 
var ajax_xmlhttp;    //ajax对象 
var div_word=null;    //当前提示层对应的搜索值 
var li_num=-1;     //伪光标位置,提示层被选中的li序号,从0开始 
var li_down=-1;     //鼠标按下提示层的序号 
var value_ed="";    //输入框延迟前的值 
var value_ing="";    //输入框当前的值 
var value_unexit="";   //搜索过没有结果的值开头 
var updown_run=false;   //允许方向键上下 
var ajax_run=false;    //true为正常进程,false停止ajax 
var ajax_run_ing=false;   //true正在运行,false空闲 
var input_focus=false;   //文本框焦点 
var url="ajax.asp";    //后台地址********************************************************** 
var time_delayajax=300;   //搜索延迟********************************************************** 
var time_delayupdown=100;  //方向键延迟******************************************************** 
  
var $=function(Fun_id){ 
 return document.getElementById(Fun_id); 
try
 ajax_xmlhttp= new ActiveXObject('Msxml2.XMLHTTP'); 
}catch(e){ 
 try
  ajax_xmlhttp= new ActiveXObject('Microsoft.XMLHTTP'); 
 }catch(e){ 
  try
   ajax_xmlhttp= new XMLHttpRequest(); 
  }catch(e){ajax_xmlhttp=null;} 
 
////////////////////////创建提示层//////////////////////// 
function createajaxdiv(){ 
 var create_div = document.createElement("div"); 
 create_div.type = "div"
 var promptdiv = document.body.appendChild(create_div); 
 promptdiv.className = "ajaxsearch"
 obj_div=promptdiv; 
////////////////////////设置提示层位置//////////////////////// 
function removediv(){ 
 if(!obj_div || !obj_input)return false
 if(obj_div.style.display=="none")return false
 var obj=obj_input; 
 var xtop=0; 
 var xleft=0; 
 while(obj){ 
  xtop += obj["offsetTop"]; 
  xleft += obj["offsetLeft"]; 
  obj = obj.offsetParent; 
 
 obj_div.style.left = xleft + "px"
 obj_div.style.top = (xtop + 20) + "px";    //20差不多是输入框的高度,请根据实际情况调整************************************************************8 
 li_down=-1; 
////////////////////////隐藏提示层//////////////////////// 
function hideajaxdiv(){ 
 obj_div.style.display="none"
 li_down=-1; 
////////////////////////设置被选<li>css样式//////////////////////// 
function setlistyle(){ 
 for(var i=0;i<obj_div.firstChild.childNodes.length;i++){ 
  obj_div.firstChild.childNodes[i].id=""
 
 if(li_num!=-1)obj_div.firstChild.childNodes[li_num].id="liseleted"
////////////////////////鼠标经过提示层//////////////////////// 
function overli(Fun_seletedlinum){ 
 if(li_num==-1)value_ing=obj_input.value; 
 li_num=Fun_seletedlinum; 
 setlistyle(); 
////////////////////////鼠标拖动提示层//////////////////////// 
function moveli(){ 
 if(window.getSelection){ 
  setfocus(); 
  window.getSelection().removeAllRanges(); 
 }else
  document.selection.empty(); 
  setfocus(); 
 
////////////////////////鼠标按下提示层//////////////////////// 
function downli(Fun_seletedlinum){ 
 if(!obj_input)return false
 li_down=Fun_seletedlinum; 
 input_focus=true
////////////////////////鼠标弹起提示层//////////////////////// 
function upli(Fun_seletedlinum,Fun_event){ 
 if(!obj_input)return false
 if(Fun_event.button==2){li_down=-1;return
 if(li_down!=Fun_seletedlinum){ 
  li_down=-1; 
  return false
 
 clearTimeout(ajax_delay); 
 clearTimeout(updown_delay); 
 updown_run=true
 ajax_run=false
 ajax_run_ing=false
 li_num=-1; 
 div_word=null
  
 value_ed=obj_div.firstChild.childNodes[Fun_seletedlinum].childNodes[1].nodeValue; 
 obj_input.value=value_ed; 
 value_ing=value_ed; 
 hideajaxdiv(); 
 obj_div.innerHTML=""
////////////////////////设置文本框获取焦点/////////////////////// 
function setfocus(){ 
 if(window.event){ 
  var r = obj_input.createTextRange(); 
  r.moveStart('character',obj_input.value.length); 
  r.collapse(true); 
  r.select(); 
 }else
  obj_input.selectionStart=obj_input.value.length; 
  obj_input.focus(); 
 
////////////////////////文本框失去焦点//////////////////////// 
function blurdeal(){ 
 if(input_focus==true){ 
  setfocus(); 
  setTimeout("setfocus()"); 
  return false
 
 updown_run=false
 ajax_run=false
 ajax_run_ing=false
 clearInterval(main_delay); 
 clearTimeout(ajax_delay); 
 clearTimeout(updown_delay); 
 hideajaxdiv(); 
 if(value_ed!=obj_input.value)obj_div.innerHTML=""
////////////////////////文本框获取焦点//////////////////////// 
function focusdeal(Fun_event){ 
 if(!obj_div)createajaxdiv(); 
 if(input_focus==true){ 
  input_focus=false
  return false
 
 var obj=((window.event)?Fun_event.srcElement:Fun_event.target); 
 if(obj.type!="text")return false
 updown_run=true
 ajax_run=true
 ajax_run_ing=false
 if(obj_input==obj && value_ed==obj.value && obj_div.innerHTML!=""){ 
  obj_div.style.display="block"
  removediv(); 
 }else
  obj_input=obj; 
  value_ed=obj.value; 
  value_ing=obj.value; 
  value_unexit=""
  li_num=-1; 
  li_down=-1; 
  div_word=null
  obj_div.innerHTML=""
  removediv(); 
 
 main_delay=setInterval("mainajax()",10); 
////////////////////////主函数//////////////////////// 
function mainajax(){ 
 if(value_ed==obj_input.value)return false
 if(value_unexit!="" && (obj_input.value).indexOf(value_unexit)==0){hideajaxdiv();obj_div.innerHTML="";return false;} 
 if(value_ed!=obj_input.value && ajax_run_ing==false){ 
  ajax_run=true
  value_ed=obj_input.value; 
  clearTimeout(ajax_delay); 
  if(obj_input.value!=""){ 
   ajax_delay=setTimeout("getsearch();",time_delayajax); 
  }else
   hideajaxdiv(); 
   obj_div.innerHTML=""
   ajax_run=false
   return false
      
  }   
 
////////////////////////获取搜索内容//////////////////////// 
function getsearch(){ 
 var temp_value=obj_input.value; 
 if(ajax_xmlhttp==null){ 
  return false
 }else if(ajax_xmlhttp.readyState!=0){ 
  ajax_xmlhttp.abort(); 
  ajax_run_ing=false
 
 ajax_xmlhttp.onreadystatechange=function(){ 
  if(ajax_run==false){ajax_xmlhttp.abort();ajax_run_ing=false;return false;} 
  if(ajax_xmlhttp.readyState==4){ 
   obj_div.innerHTML=""
   if(ajax_xmlhttp.status==200 || ajax_xmlhttp.status==304){ 
    var contant=ajax_xmlhttp.responseText; 
    if(contant!="" && ajax_run==true){ 
     div_word=temp_value; 
     obj_div.innerHTML=resetcontant(contant); 
     obj_div.style.display="block"
     removediv();removediv(); 
    }else
     hideajaxdiv(); 
    
    updown_run=true
    ajax_run_ing=false
    li_num=-1; 
    if(contant=="")value_unexit=temp_value; 
   
  
 
 ajax_xmlhttp.open("post",url,true); 
 ajax_xmlhttp.setRequestHeader('Content-type','application/x-www-form-urlencoded'); 
 ajax_run_ing=true
 ajax_xmlhttp.send("sift_value="+escape(temp_value)); //提交到后台的值***************************************** 
////////////////////////内容重组/////////////////////// 
function resetcontant(Fun_contant){ 
 if(Fun_contant==null || Fun_contant=="")return ""
 var a=Fun_contant.substring(1,Fun_contant.length-1); 
 if(Fun_contant==null || Fun_contant=="")return ""
 var b=a.split("''"); 
 var c; 
 var d; 
 d="<ul>"
 for(var i in b){ 
  c=b[i].split(","); 
  //*************************************************************** 
  d=d+"<li onmouseover=\"overli("+i+");\" onmousedown=\"downli("+i+")\" onmouseup=\"upli("+i+",event)\" onmousemove=\"moveli();\"><span>"+c[1]+"</span>"+c[0]+"</li>"//约 结果
  //*************************************************************** 
 
 d=d+"<li onmousedown=\"input_focus=true;li_down=-1;\" onmouseup=\"li_down=-1\" onmousemove=\"moveli();\"><span><a class=\"shutajaxdiv\" onclick=\"hideajaxdiv();\">关闭</a></span></li>"
 d=d+"</ul>"
 return d; 
////////////////////////键盘事件//////////////////////// 
function keydowndeal(Fun_event){ 
 var keyc=((window.event)?Fun_event.keyCode:Fun_event.which); 
 if(keyc==13){hideajaxdiv();return false;} 
 if(keyc==27){ 
  if(obj_div.style.display=="block" && li_num>-1)value_ed=obj_input.value=value_ing; 
  hideajaxdiv(); 
  return false
 }  
 if(keyc==40 || keyc==38){ 
  if(div_word==obj_input.value && obj_div.style.display=="none" && obj_div.innerHTML!=""){ 
   obj_div.style.display="block"
   removediv(); 
   return false
  
  if(li_num==-1){ 
   if(div_word!=obj_input.value)return false
  }else
   if(div_word!=value_ing)return false
  
  if(updown_run==false || ajax_run_ing==true || obj_div.style.display=="none")return false
  updown_delay=setTimeout("updownli("+keyc+")",time_delayupdown); 
  updown_run=false
 
////////////////////////方向键移动li//////////////////////// 
function updownli(Fun_key){ 
 if(!obj_div){return false;} 
 updown_run=true
 if(li_num==-1){ 
  if(div_word!=obj_input.value){hideajaxdiv();obj_div.innerHTML="";li_num=-1;return false;} 
 }else
  if(div_word!=value_ing){hideajaxdiv();obj_div.innerHTML="";li_num=-1;return false;} 
 
 if(updown_run==false)return false
 if(li_num==-1)value_ing=value_ed; 
 if(Fun_key==40){ 
  if(li_num<obj_div.firstChild.childNodes.length-2){ 
   li_num++; 
  }else
   li_num=-1; 
  
 
 if(Fun_key==38){ 
  if(li_num>=0){ 
   li_num--; 
  }else
   li_num=obj_div.firstChild.childNodes.length-2; 
  
 
 if(li_num!=-1){ 
  value_ed=obj_input.value=obj_div.firstChild.childNodes[li_num].childNodes[1].nodeValue; 
 }else
  value_ed=obj_input.value=value_ing; 
 
 setlistyle(); 
}

 ajax.asp

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<%@LANGUAGE="VBSCRIPT" CODEPAGE="65001" %> 
<%Response.CodePage="65001"%> 
<%Response.Charset="utf-8" %> 
 
<!--#include file="Conn.asp"-->
<% 
 
 
 
dim Sift_value 
dim Sql,Rs,I,Num 
dim Contant 
Contant=""
Num=10 
 
 
Sift_value=replace(unescape(request.form("sift_value")),"""",""""""
  
Sql="select top "&Num&" ShopAddress,LicenseId from LC where ShopAddress like '%"&Sift_value&"%' order by LicenseId"
'Response.Write Sql
set Rs=server.CreateObject("adodb.recordset"
Rs.open Sql,O_con,1,1 
if not (Rs.eof and Rs.bof) then 
 for I=0 to Num-1 
  Contant=Contant&"'"&rs(0)&","&rs(1)&"'"
  Rs.movenext 
  if Rs.eof then exit for 
 next 
end if 
response.Write(Contant) 
Rs.close 
set Rs=nothing 
%>

 

posted @   ®Geovin Du Dream Park™  阅读(456)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
历史上的今天:
2012-12-22 Csharp: play media file using Windows Media Player
2012-12-22 Csharp: play media file using Microsoft.DirectX
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示