滚动新闻:
  网站首页     新闻资讯     网络安全     网页制作     办公软件     网站运营     平面设计     网络编程  
今天是,欢迎访问Ok3w新闻发布系统! 请您留言 | 免费下载 | 设为首页 | 加入收藏
您当前位置:网站首页 >> 网页制作 >> Javascript/Ajax >> 阅读文章
站内查找:

Ajax文本框输入提示


来源:互联网 发布时间:2009-05-01 00:31:29 查看次数:

一个Ajax文本框输入提示的例子,用asp实现:

前台文件

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
  2. <html xmlns="http://www.w3.org/1999/xhtml"> 
  3. <head> 
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
  5. <title>文本框输入提示</title> 
  6. <style type="text/css">...  
  7. <!--  
  8. .keyword {...}{width:150px; height:20px; border:#0066FF 1px solid;}/**//*文本框样式*/  
  9. #keytishi {...}{width:150px; height:auto; border:#0066FF 1px solid; position:absolute; display:none;}/**//*提示层样式*/  
  10. #keytishi ul {...}{ margin:0;}/**//*提示层样式*/  
  11. #keytishi ul li{...}{margin:0;list-style-type:none; line-height:16px; height:16px; font-size:12px; padding:2px;}/**//*提示层样式*/  
  12. #keytishi ul li a {...}{display:block; width:150px; height:16px; text-decoration:none;}/**//*提示层样式*/  
  13. #keytishi ul li a:hover {...}{background-color:#0099FF;}/**//*提示层样式*/  
  14. --> 
  15. </style> 
  16. <script type="text/javascript">...  
  17. <!--  
  18.  
  19. //建立XMLHttpRequest对象  
  20. var xmlhttp;  
  21. try...{  
  22.     xmlhttpnew ActiveXObject('Msxml2.XMLHTTP');  
  23. }catch(e)...{  
  24.     try...{  
  25.         xmlhttpnew ActiveXObject('Microsoft.XMLHTTP');  
  26.     }catch(e)...{  
  27.         try...{  
  28.             xmlhttpnew XMLHttpRequest();  
  29.         }catch(e)...{}  
  30.     }  
  31. }  
  32.  
  33. function getKeyWord()...{  
  34.     var obj = document.getElementById("search");//获取文本域对象  
  35.     if(obj.value=="")...{  
  36.         return;  
  37.     }  
  38.     var top=0;  
  39.     var left=0;  
  40.     while(obj)...{//此循环得到文件域对象在页面中的绝对位置  
  41.         top += obj["offsetTop"];  
  42.         left += obj["offsetLeft"];  
  43.         objobj = obj.offsetParent;  
  44.     }  
  45.     xmlhttp.open("get","input.asp?keyword="+document.getElementById("search").value,true);  
  46.     xmlhttp.onreadystatechange = function()...{  
  47.         if(xmlhttp.readyState == 4)  
  48.         ...{  
  49.             if(xmlhttp.status == 200)  
  50.             ...{  
  51.                 if(xmlhttp.responseText!="")...{  
  52.                     document.getElementById("keytishi").innerHTML = unescape(xmlhttp.responseText);//把后台返回的数据填充到提示层  
  53.                     document.getElementById("keytishi").style.left = left + "px";//设置提示层的位置,左  
  54.                     document.getElementById("keytishi").style.top = (top + 25) + "px";//设置提示层的位置,上  
  55.                     document.getElementById("keytishi").style.display = "block";//设置提示层可见  
  56.                 }else...{  
  57.                     document.getElementById("keytishi").innerHTML = "";//清空提示层  
  58.                     document.getElementById("keytishi").style.display = "none";//设置提示层不可见  
  59.                 }  
  60.             }  
  61.             else...{  
  62.               
  63.             }  
  64.         }  
  65.     }  
  66.     xmlhttp.setRequestHeader("If-Modified-Since","0");  
  67.     xmlhttp.send(null);  
  68. }  
  69. function input(str)...{  
  70.     document.getElementById("search").value=str;//从提示层选择你需要的数据填充到文本框  
  71.     document.getElementById("keytishi").innerHTML = "";//清空提示层  
  72.     document.getElementById("keytishi").style.display = "none";//设置提示层不可见  
  73. }  
  74. //--> 
  75. </script> 
  76. </head> 
  77. <body> 
  78. <input type="text" class="keyword" id="search" name="search" onkeyup="getKeyWord();" onclick="getKeyWord();" /> 
  79. <div id="keytishi"></div><!--提示层--> 
  80. </body> 
  81. </html> 

后台文件 [input.asp]

  1. <%...@LANGUAGE="VBSCRIPT" CODEPAGE="65001"%> 
  2. <!--#include file="conn.asp"--> 
  3. <%...  
  4.     dim rs  
  5.     dim sql  
  6.       
  7.     dim keyWords  
  8.       
  9.     keyWrods = Request("keyword")  
  10.       
  11.     Set rs = Server.CreateObject("ADODB.Recordset")  
  12.     sql = "select * from king_test where keyword like '%"&keyWrods&"%'"  
  13.     rs.open sql,conn,1,1  
  14.     if not (rs.bof and rs.eof) then  
  15.     Response.Write("<ul>")  
  16.     do while not rs.eof  
  17. %> 
  18. <li><a href="javascript:void(null);" onclick="input('<%Response.Write(escape(rs("keyword")))%>');"><%...Response.Write(escape(rs("keyword")))%></a></li> 
  19. <%...  
  20.     rs.movenext  
  21.     loop  
  22.     Response.Write("<ul>")  
  23.     end if  
  24.     rs.close  
  25.     set rs = nothing 
  26.     conn.close  
  27.     Set conn = nothing 
  28. %> 

escape与unescape是用来编码的和解码的,这是为了避免汉字出现乱码,在XP + IE6,7,Firefox测试通过

·上一条:AJAX的类库中使用服务接口定义[ASP.NET]
·下一条:AJAX应用中使用TODO服务[ASP.NET]
相关文章
·Ajax是什么 2009-05-01 00:43:25
·Ajax 技术从入门到精髓 2009-05-01 00:40:32
·最基本的AJAX框架的实现方法 2009-05-01 00:38:02
·AJAX调用WCF服务项模板[ASP.NET] 2009-05-01 00:35:24
·AJAX的类库中使用服务接口定义[ASP.NET] 2009-05-01 00:34:14
·Ajax文本框输入提示 2009-05-01 00:31:29
·AJAX应用中使用TODO服务[ASP.NET] 2009-05-01 00:30:32
·Web2.0网站攻击新潮—Ajax Hacking 2009-05-01 00:20:36
文章评论
现在有0人对本文发表评论 查看所有评论
赞助商链接
  最新更新
·Ajax是什么
·Ajax 技术从入门到精髓
·最基本的AJAX框架的实现方法
·AJAX调用WCF服务项模板[ASP.NET]
·AJAX的类库中使用服务接口定义[ASP.NET]
·Ajax文本框输入提示
·AJAX应用中使用TODO服务[ASP.NET]
·Web2.0网站攻击新潮—Ajax Hacking
·Ajax让网页木马“悄悄的执行”
  阅读排行
·Ajax 技术从入门到精髓
·Ajax让网页木马“悄悄的执行”
·Web2.0网站攻击新潮—Ajax Hacking
·Ajax是什么
·AJAX调用WCF服务项模板[ASP.NET]
·最基本的AJAX框架的实现方法
·Ajax文本框输入提示
·AJAX应用中使用TODO服务[ASP.NET]
·AJAX的类库中使用服务接口定义[ASP.NET]
关于我们 | 使用说明 | 联系方式 | 免责声明 | 免费下载 | 有事请留言 | 滇ICP备08101427号
联系邮箱:zhengbi888@yahoo.com.cn 在线QQ:124895502
Copyright 2009, 版权所有 www.glzy8.com.