国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 編程 > 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風格實現下拉菜單效果的代碼,希望對大家的學習有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
国产精品视频一区二区久久| 国产视频中文字幕在线观看| 国产日产一区二区| 久热国产在线| 国产鲁鲁视频在线观看免费| 天天av天天爽| 伊人精品影院| 国产资源在线看| 国产在线视频网站| 国产激情视频在线观看| 在线三级中文| 丁香婷婷在线观看| 国产高清av| 黄色片av在线| 夜夜爽视频导航| 国产一二三区在线视频| www亚洲天堂| 精品入口麻豆传煤| 国产在线激情视频| av二区三区| 国产香蕉尹人视频在线| baoyu777.永久免费视频| 国产天堂素人系列在线视频| 亚洲欧美一区二区三区在线播放| 女同一区二区免费aⅴ| 国产福利图片| 中文字幕av中文字幕| 免费网站看黄yyy222| 中文一区在线观看| 国产精品国产三级国产试看| 黄网址在线播放免费| 日本韩国精品一区二区| 亚洲日本久久久午夜精品| 国产aa视频| 国产第一页在线视频| 国产精品入口免费麻豆| 天天爱天天做色综合| 狠狠色丁香婷婷| 牛牛热在线视频| 欧洲亚洲精品视频| 超碰97在线免费观看| 日本在线视频www鲁啊鲁| 在线观看午夜av| 性网站在线播放| sese在线视频| 麻豆精品传媒视频观看| 国产伦精品一区二区三区高清版禁 | 精品卡1卡2卡三卡免费网站| 久久精品国产亚洲777| 免费精品国产自产拍观看| 欧美日韩亚洲第一页| 日本视频在线| 丁香婷婷在线观看| 中文字幕免费中文| √8天堂资源地址中文在线| 精品一区二区观看| www中文字幕在线观看| 国产在线看片| 国产精品黄页网站在线播放免费| 在线一区观看| 国产理论电影在线| 精品无人区乱码1区2区3区免费| av一级在线| 另类综合图区| 2021av天天| 国产资源在线看| 伊人222成人综合网| 六月天色婷婷| 在线免费看av| 中文字幕第一页在线| 四虎久久影院| 国产亚洲精品拍拍拍拍拍| 伊人网在线观看| 国产亚洲精品午夜高清影院| 亚洲国产精华液| 天堂在线免费视频| www.操.com| 99re热视频在线| 黄色av网站在线免费观看| 国产福利资源| 中文字幕日本三级| xxxxx中文字幕| 99热国产在线| 国产区成人精品视频| 黄色片视频在线观看| av免费在线观| 在线观看视频污| 999福利在线视频| 国产福利图片| 国产精品伦理一区二区三区| 丁香视频免费观看| 开心婷婷激情五月| eeuss影院在线观看第一页| 国产精品扒开做爽爽爽的视频| 久久久久久77777| 久热中文字幕在线观看| www.色婷婷| 日本福利午夜视频在线| 亚洲第一区视频| 在线国产网址| h视频在线网站| 久热国产在线| 国产一二三区精品视频| 国产丝袜精品丝袜| 国产福利在线观看| 伊人免费视频| 欧美日韩不卡中文字幕在线| 欧美另类在线视频| 免费观看v片在线观看| 九九久久久2| 国产三级在线免费观看| 国产福利免费在线观看| 在线成人一区| 久久久久国产精品嫩草影院| 99视频免费在线观看| 国产高清免费在线播放| 亚洲精品自产拍在线观看| 欧洲亚洲精品视频| 国产一级网站视频在线| 中文在线有码| 国产免费自拍视频| 国产爆初菊在线观看免费视频网站 | 青青草原国产在线| 好吊日视频在线观看| 国产精品久久久久久久牛牛 | 久久久久国产精品嫩草影院| 国产一区二区三区四区尤物| 91视频久色| 国产在线免费观看| 999在线视频| 久久国产情侣| 精品一区二区91| 国产蜜臀在线| av在线网页| 国产精品美女一区二区视频| 亚洲成人在线播放| 国产无套粉嫩白浆在线2022年| 亚洲精品视频区| 国产精品免费视频一区一| 超碰97在线免费观看| 国产成人午夜电影| 国产精品一区二区三区视频网站| 在线中文字幕av| 国产黄在线观看| 国产一级在线观看www色| 亚洲第一页在线播放| 国产三级在线看| 在线91av| 国产卡一卡二卡三| 国产农村av| 久久国产精品黑丝| 欧美色欧美亚洲另类二区精品| av高清在线| 中文在线视频观看| 国产精品白浆流出视频| 国产精品自产拍在线观看2019| 免费中文字幕| 久久久久国产精品嫩草影院| www.91在线播放| 青草视频在线播放| 波多野结衣中文字幕久久| 精品全国在线一区二区| 92久久精品| 在线观看av网站| 在线三级中文| 天天草天天干| 久热国产在线| 国产另类图片| 国产三级视频在线看| 国产区在线看| 亚洲人在线播放| 黄色片视频在线观看| 天天操天天曰| 国产成人久久精品77777| 精品无人乱码| 欧洲一区av| 久久精品视频免费看| 黄色电影网站在线观看| 中文字幕免费中文| 91精品专区| 超碰91在线| 国产偷倩在线播放| 在线播放黄色网址| 国产专区在线| 伊人影院在线观看| 久久精品国产亚洲777| 中文字幕视频免费在线观看| 精品美女视频在线观看免费软件| 日本电影在线观看| 国产婷婷视频在线| 欧美日韩国产亚洲沙发| 国产精品一区二区三区视频网站| 国产精品久久麻豆| 免费看的av| 99在线视频影院| 最近免费中文字幕大全免费第三页 | av网址在线看| 国产天堂素人系列在线视频| 四虎网站在线观看| 国产99在线|亚洲|