麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 編程 > ASP > 正文

ASP模仿google suggest風(fēng)格實(shí)現(xiàn)下拉菜單效果

2024-05-04 11:10:06
字體:
供稿:網(wǎng)友

這篇文章主要介紹了ASP模仿google suggest風(fēng)格實(shí)現(xiàn)下拉菜單效果,需要的朋友可以參考下

今天和大家一起利用ASP模仿實(shí)現(xiàn)google suggest風(fēng)格的下拉菜單,直接上代碼

1.前臺(tái)代碼:

 

 
  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.   //取得子節(jié)點(diǎn)內(nèi)容,重新裝載為數(shù)組 
  104.   var nextNode=e.getElementsByTagName("name")[0].firstChild.data; 
  105.   //創(chuàng)建tr,td,span元素 
  106.         row =document.createElement("tr"); 
  107.         cell =document.createElement("td"); 
  108.   //spans=document.createElement("span"); 
  109.   //設(shè)置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.   //裝載隱藏?cái)?shù)據(jù)到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.   //填充數(shù)據(jù)到web頁(yè)面,cell---->td對(duì)象 
  155.       inputField.value = cell.firstChild.nodeValue; 
  156.       clearNames(); 
  157.     } 
  158.     //清除列表數(shù)組 
  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">提示:輸入關(guān)鍵字,程序自動(dòng)從庫(kù)中匹配您 
  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.后臺(tái)search.asp異步查詢數(shù)據(jù)頁(yè)面

把sql語句和要顯示的字段改為自己的數(shù)據(jù)庫(kù)相對(duì)應(yīng)格式就可以了。

 

 
  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風(fēng)格實(shí)現(xiàn)下拉菜單效果的代碼,希望對(duì)大家的學(xué)習(xí)有所幫助。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 久久亚洲精品久久国产一区二区 | chinese xxxx hd pron8 tube | 一级看片免费视频 | 国产一国产精品一级毛片 | 日韩大片在线永久观看视频网站免费 | 国产成人自拍视频在线观看 | 91成人免费电影 | 国产人成免费爽爽爽视频 | 欧美成人黄色小视频 | 91一区二区在线观看 | 日日草夜夜操 | 亚洲综合视频网站 | av成人在线电影 | 日韩a毛片免费观看 | 99爱视频 | 国产精品a一 | 成人午夜免费看 | 亚洲无av | 欧美日韩免费看 | 欧美一级特黄aaaaaa在线看首页 | 国产成人精品午夜 | 香蕉国产在线视频 | av影院在线播放 | 亚州综合| 日韩视频―中文字幕 | 免费国产精品视频 | 国产黄色免费网站 | 久久久久成人免费 | 国产精品久久久久网站 | 国产免费高清在线 | 欧美午夜网 | 一级电影免费看 | 国产精品成年片在线观看, 激情小说另类 | 国产午夜免费视频 | 精品一区二区三区在线观看视频 | 日韩视频区 | 久精品国产 | 成人毛片视频在线观看 | 色播久久 | 99ri在线| 欧美成人一二三区 |