亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > ASP > 正文

ASP模仿google suggest風格實現下拉菜單效果

2024-05-04 11:10:06
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了ASP模仿google suggest風格實現下拉菜單效果,需要的朋友可以參考下

今天和大家一起利用ASP模仿實現google suggest風格的下拉菜單,直接上代碼

1.前臺代碼:

 

 
  1. <%@LANGUAGE="JAVASCRIPT" CODEPAGE="936"%> 
  2. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"  
  3.  
  4. "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
  5. <html xmlns="http://www.w3.org/1999/xhtml"
  6. <style type="text/css"
  7. <!-- 
  8. .style1 {color: #FF0000} 
  9. .mouseOut 
  10. font-size:12px; 
  11. background: #708090; 
  12. color: #FFFAFA; 
  13.    
  14. .mouseOver 
  15. font-size:12px; 
  16. background: #FFFAFA; 
  17. color: #000000; 
  18. --> 
  19. </style> 
  20.    <script type="text/javascript" language="javascript"
  21.     var xmlHttp; 
  22.     var completeDiv; 
  23.     var inputField; 
  24.     var nameTable; 
  25.     var nameTableBody; 
  26.     var flag=false
  27.    
  28.     function createXMLHttpRequest() { 
  29.       if (window.ActiveXObject) { 
  30.         xmlHttp = new ActiveXObject("Microsoft.XMLHTTP"); 
  31.       } 
  32.       else if (window.XMLHttpRequest) { 
  33.         xmlHttp = new XMLHttpRequest();         
  34.       } 
  35.     } 
  36.      
  37.     function setflag(){ 
  38.       flag = true
  39.     } 
  40.      
  41.     function DisSelect() 
  42.     { 
  43.       if(flag==false
  44.       document.getElementById("popup").style.display="none"
  45.     } 
  46.    
  47.     function initVars() { 
  48.       inputField = document.getElementById("frmchangshang");       
  49.       nameTable = document.getElementById("name_table"); 
  50.       completeDiv = document.getElementById("popup"); 
  51.       nameTableBody = document.getElementById("name_table_body"); 
  52.       document.getElementById("popup").style.display="block"
  53.     } 
  54.    
  55.     function findNames() { 
  56.       initVars(); 
  57.       if (inputField.value.length > 0) 
  58.   { 
  59.         createXMLHttpRequest(); 
  60.         var url = "search.asp?names=" + inputField.value;  
  61.         xmlHttp.open("GET", url, true); 
  62.         xmlHttp.onreadystatechange = callback; 
  63.         xmlHttp.send(null); 
  64.       } 
  65.   else 
  66.   { 
  67.         clearNames(); 
  68.       } 
  69.     } 
  70.    
  71.     function callback() { 
  72.       if (xmlHttp.readyState == 4) { 
  73.         if (xmlHttp.status == 200) 
  74.         { 
  75.    try 
  76.           { 
  77.             var name = xmlHttp.responseXML.getElementsByTagName("name"
  78.  
  79. [0].firstChild.data; 
  80.           } 
  81.           catch(e) 
  82.           { 
  83.             document.getElementById("popup").style.display="none"
  84.             clearNames(); 
  85.           } 
  86.           setNames(xmlHttp.responseXML.getElementsByTagName("content")); 
  87.         } 
  88.         else if (xmlHttp.status == 204) 
  89.         { 
  90.           clearNames(); 
  91.         } 
  92.       } 
  93.     } 
  94.      
  95.     function setNames(the_names) {       
  96.       clearNames(); 
  97.       var size = the_names.length; 
  98.       setOffsets(); 
  99.       var row,cell,spans; 
  100.       for (var i = 0; i < size; i++) { 
  101.         //var nextNode = the_names[i].firstChild.data; 
  102.   var e = the_names[i]; 
  103.   //取得子節點內容,重新裝載為數組 
  104.   var nextNode=e.getElementsByTagName("name")[0].firstChild.data; 
  105.   //創建tr,td,span元素 
  106.         row =document.createElement("tr"); 
  107.         cell =document.createElement("td"); 
  108.   //spans=document.createElement("span"); 
  109.   //設置cell屬性 
  110.         cell.onmouseout = function() {this.className='mouseOver'; flag=false;}; 
  111.         cell.onmouseover = function() {this.className='mouseOut'; flag=true;}; 
  112.         cell.setAttribute("bgcolor","#FFFAFA"); 
  113.         cell.setAttribute("border","0"); 
  114.         //cell.setAttribute("onmouseover","setflag()"); 
  115.         cell.onclick = function() { populateName(this); }; 
  116.   //將nextNode添加到td 
  117.   var txtName = document.createTextNode(nextNode); 
  118.   cell.appendChild(txtName); 
  119.   //裝載隱藏數據到span元素 
  120.   row.appendChild(cell); 
  121.         nameTableBody.appendChild(row); 
  122.       } 
  123.     } 
  124.    
  125.     function setOffsets() { 
  126.       var end = inputField.offsetWidth; 
  127.       var left = calculateOffsetLeft(inputField); 
  128.       var top = calculateOffsetTop(inputField) + inputField.offsetHeight; 
  129.    
  130.       completeDiv.style.border = "black 1px solid"
  131.       completeDiv.style.left = left + "px"
  132.       completeDiv.style.top = top + "px"
  133.       nameTable.style.width="400px"
  134.     } 
  135.      
  136.     function calculateOffsetLeft(field) { 
  137.      return calculateOffset(field, "offsetLeft"); 
  138.     } 
  139.    
  140.     function calculateOffsetTop(field) { 
  141.      return calculateOffset(field, "offsetTop"); 
  142.     } 
  143.    
  144.     function calculateOffset(field, attr) { 
  145.      var offset = 0; 
  146.      while(field) { 
  147.       offset += field[attr]; 
  148.       field = field.offsetParent; 
  149.      } 
  150.      return offset; 
  151.     } 
  152.    
  153.     function populateName(cell) { 
  154.   //填充數據到web頁面,cell---->td對象 
  155.       inputField.value = cell.firstChild.nodeValue; 
  156.       clearNames(); 
  157.     } 
  158.     //清除列表數組 
  159.     function clearNames() { 
  160.       var ind = nameTableBody.childNodes.length; 
  161.       for (var i = ind - 1; i >= 0 ; i--) { 
  162.          nameTableBody.removeChild(nameTableBody.childNodes[i]); 
  163.       } 
  164.       completeDiv.style.border = "none"
  165.     } 
  166. </script> 
  167. <head> 
  168. <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
  169. <title>Untitled Document</title> 
  170. </head> 
  171.    
  172. <body> 
  173. <input name="frmchangshang" class="InputText" id="frmchangshang" style="width:250px;" 
  174.  
  175. onBlur="DisSelect();" onKeyUp="findNames();" size="50" maxlength="100"
  176.           <span class="style1">提示:輸入關鍵字,程序自動從庫中匹配您 
  177.  
  178. 要找的記錄,如果不存在自行填寫 
  179.      </span> 
  180.           <div style="position:absolute;top:0;left:0;" id="popup"
  181.             <table id="name_table" bgcolor="#FFFAFA" border="0" cellspacing="0" 
  182.  
  183. cellpadding="0">       
  184.               <tbody id="name_table_body"></tbody> 
  185.             </table> 
  186.          </div> 
  187. </body> 
  188. </html> 

2.后臺search.asp異步查詢數據頁面

把sql語句和要顯示的字段改為自己的數據庫相對應格式就可以了。

 

 
  1. <!--#include virtual="conn.asp" --> 
  2. <% 
  3. keyword=request.QueryString("names"
  4. sql="select lgid,lgmc from lg where lgmc like '%"&keyword&"%' order by lgid desc" 
  5. set rs=server.CreateObject("adodb.recordset"
  6. rs.open sql,conn,1,1 
  7. Response.ContentType="text/xml"   
  8. response.Write "<?xml version=""1.0"" encoding=""GB2312"" ?>" 
  9. response.Write "<response>" 
  10. do while not rs.eof 
  11. response.Write "<content>" 
  12. response.Write "<name>"&rs("lgmc")&"</name>" 
  13. 'response.Write "<userid>"&rs("userid")&"</userid>" 
  14. 'response.Write "<startime>"&rs("startime")&"</startime>" 
  15. 'response.Write "<endtime>"&rs("endtime")&"</endtime>" 
  16. response.Write "</content>" 
  17. rs.movenext 
  18. loop 
  19. response.Write "</response>" 
  20. rs.close 
  21. set rs=nothing 
  22. %> 

以上就是ASP模仿google suggest風格實現下拉菜單效果的代碼,希望對大家的學習有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产日韩欧美夫妻视频在线观看| 精品日本美女福利在线观看| 欧美激情奇米色| 欧美黄网免费在线观看| 成人xvideos免费视频| 欧美老妇交乱视频| 丝袜亚洲欧美日韩综合| 亚洲色在线视频| 国产噜噜噜噜噜久久久久久久久| 亚洲欧美日韩一区二区在线| 中文字幕日韩在线播放| 久久精品免费播放| 精品无人区太爽高潮在线播放| 日本久久久久久久久| 日本亚洲欧美三级| 欧美日韩在线观看视频小说| 欧美国产日韩免费| 欧美精品久久久久| 成人免费网站在线| 大伊人狠狠躁夜夜躁av一区| 中文字幕久热精品视频在线| 欧美精品videos| 日韩精品久久久久久福利| 亚洲欧美一区二区三区久久| 欧美激情va永久在线播放| 欧美激情在线狂野欧美精品| 欧美成人午夜激情| 疯狂蹂躏欧美一区二区精品| 国产日韩欧美91| 久久精品一区中文字幕| 成人久久18免费网站图片| 亚洲精品美女久久久久| 国产香蕉97碰碰久久人人| 日韩av在线网| 欧美综合一区第一页| 国产成人avxxxxx在线看| 97精品久久久中文字幕免费| 欧美精品videossex性护士| 午夜精品福利在线观看| 一本色道久久综合狠狠躁篇怎么玩| 日韩精品在线观看视频| 久久噜噜噜精品国产亚洲综合| 欧美一区二区.| 国产91在线播放精品91| 亚洲午夜av久久乱码| 久久免费成人精品视频| 日韩综合视频在线观看| 综合国产在线观看| 久久久免费观看| 日韩精品免费电影| 欧美日韩国产麻豆| 欧美黑人巨大xxx极品| 国产一区二区三区中文| 久久久国产精品免费| 91超碰caoporn97人人| 韩国三级电影久久久久久| 亚洲男人天堂2019| 欧美最猛性xxxxx(亚洲精品)| 欧美日韩国产成人在线观看| 欧美精品在线免费播放| 欧美性猛交xxx| 91精品综合视频| 97热在线精品视频在线观看| 欧美一级免费看| 亚洲性夜色噜噜噜7777| 欧美一级黄色网| 亚洲国产精品va| 国产视频欧美视频| 欧美激情一级精品国产| 欧美日韩福利电影| 91sao在线观看国产| 疯狂做受xxxx高潮欧美日本| 久久中文字幕在线| 久久精品中文字幕一区| 91网站在线免费观看| 性欧美办公室18xxxxhd| 日韩精品一区二区三区第95| 亚洲第一精品自拍| 中文字幕精品影院| 久久亚洲一区二区三区四区五区高| 国产成人中文字幕| 久久精品国产免费观看| 久久精品久久久久久| 亚洲国产精品va在线| 91啪国产在线| 日韩在线视频一区| 国产91热爆ts人妖在线| 成人www视频在线观看| 日韩av高清不卡| 中文综合在线观看| www国产精品视频| 韩国v欧美v日本v亚洲| 国产精品久久久久久久av电影| 亚洲精品成人网| 91影视免费在线观看| 欧美亚洲在线视频| 51ⅴ精品国产91久久久久久| 国产精自产拍久久久久久蜜| 91精品国产91久久久| 成人福利在线视频| 中文字幕亚洲综合久久筱田步美| 日韩有码在线电影| 亚洲成人av在线| 国产精品麻豆va在线播放| 日韩精品免费一线在线观看| 欧美成人午夜激情视频| 热re99久久精品国产66热| 欧美性理论片在线观看片免费| 欧美国产亚洲视频| 2019亚洲男人天堂| 两个人的视频www国产精品| 懂色aⅴ精品一区二区三区蜜月| 亚洲国产精品成人一区二区| 久久99精品久久久久久琪琪| 69国产精品成人在线播放| 欧美高清无遮挡| 久久精品国产成人精品| 色偷偷91综合久久噜噜| 欧美巨大黑人极品精男| 国内免费精品永久在线视频| 欧美日韩成人在线视频| 91av网站在线播放| 亚洲第一中文字幕在线观看| 国内精品久久久久伊人av| 亚洲午夜国产成人av电影男同| 国产精品久久在线观看| 中文字幕欧美日韩| 亚洲激情在线视频| 国产一区二区香蕉| 国产日产欧美a一级在线| 久久久国产一区二区三区| 91在线观看免费| 亚洲人精选亚洲人成在线| 日韩欧美国产一区二区| 亚洲精品suv精品一区二区| 日韩免费精品视频| 精品夜色国产国偷在线| 成人黄色av网站| 92裸体在线视频网站| 亚洲第一在线视频| 亚洲精品视频久久| 2018国产精品视频| 久久综合免费视频影院| 狠狠色香婷婷久久亚洲精品| 国产精品27p| 日韩精品视频在线观看网址| 色琪琪综合男人的天堂aⅴ视频| 久久综合久久八八| 久久久亚洲精选| 久久综合亚洲社区| 日本aⅴ大伊香蕉精品视频| 亚洲高清不卡av| 亚洲高清在线观看| 欧美成人精品一区二区三区| 国内精品小视频| 欧美怡春院一区二区三区| 精品国产一区二区在线| 国产精品美腿一区在线看| 中文字幕av一区二区| 中文字幕亚洲综合久久筱田步美| 欧美孕妇孕交黑巨大网站| 日韩欧美aⅴ综合网站发布| 精品亚洲国产成av人片传媒| 国产精品视频1区|