国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁/技術(shù)文章
文章詳情頁

使用Ajax模仿百度搜索框的自動(dòng)提示功能實(shí)例

瀏覽:202日期:2022-06-11 10:35:20

啊啊,熬夜了。今天學(xué)習(xí)了ajax給我的感覺就是,”哇塞“ajax好酷炫哦,(額。。。后端狗,接觸到了大前端的魅力了),這么晚了還是直奔主題把。Let"s go!

百度搜索提示框,我想大家都很熟悉了把,是什么樣子我也就不再贅述。直接看代碼

來我們寫一個(gè)簡(jiǎn)陋的jsp頁面 Look! 是這個(gè)樣子的

下面是代碼:

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.xxx.org/TR/html4/loose.dtd"><html> <head>  <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  <title>Test Baidu</title> </head> <body> 	<!--  	文本輸入框  --> 	<div id="serach"> 		<input type="text" name="text" id="text" /> 		<input type="submit" value="搜索" /> 	</div> 	 	<!--  	提示下拉框  -->  <div id="tips";>  </div>   	</body> 	<script> 		window.onload=function(){ 			//獲取文本輸入框 			var textElment = document.getElementById("text"); 			//獲取下提示框 			var div = document.getElementById("tips"); 			textElment.onkeyup=function(){ 				//獲取用戶輸入的值 				var text = textElment.value; 				//如果文本框中沒有值,則下拉框被隱藏,不顯示 				if(text==""){ 					div.style.display="none"; 					return; 				} 				//獲取XMLHttpRequest對(duì)象 				var xhr = new XMLHttpRequest(); 				//編寫回調(diào)函數(shù) 				xhr.onreadystatechange=function(){ 					//判斷回調(diào)的條件是否準(zhǔn)備齊全 					if(xhr.readyState==4){ 						if(xhr.status==200){ 							//取的服務(wù)器端傳回的數(shù)據(jù) 							var str = xhr.responseText; 							 							//判斷傳回的數(shù)據(jù)是否為空,若是則直接返回,不顯示 							if(str==""){ 								return; 							} 							//我們將會(huì)在服務(wù)器端把數(shù)據(jù)用 , 隔開,當(dāng)然這里也可以使用json 							var result = str.split(","); 							var childs = ""; 							//遍歷結(jié)果集,將結(jié)果集中的每一條數(shù)據(jù)用一個(gè)div顯示,把所有的div放入到childs中 							for(var i=0; i<result.length;i++){ 								childs += "<div onclick="Write(this)" onmouseout="recoverColorwhenMouseout(this)" onmouseover="changeColorwhenMouseover(this)">"+result[i]+"</div>"; 							} 							//把childs 這div集合放入到下拉提示框的父div中,上面我們以獲取了 							div.innerHTML=childs; 							div.style.display="block"; 						 						} 					} 				} 			 				//創(chuàng)建與服務(wù)器的連接 				xhr.open("GET","${pageContext.request.contextPath}/test?text="+text); 			  				//發(fā)送 				xhr.send(); 			} 		} 		//鼠標(biāo)懸停時(shí)改變div的顏色 		function changeColorwhenMouseover(div){ 			div.style.backgroundColor="pink"; 		} 		//鼠標(biāo)移出時(shí)回復(fù)div顏色 		function recoverColorwhenMouseout(div){ 			div.style.backgroundColor=""; 		} 		//當(dāng)鼠標(biāo)帶點(diǎn)擊div時(shí),將div的值賦給輸入文本框 		function Write(div){ 			//將div中的值賦給文本框 			document.getElementById("text").value=div.innerHTML; 			 			//讓下拉提示框消失 			 			div.parentNode.style.display="none"; 		} 	</script></html>

再看servlet:

package com.zhuxingyi.servlet; import java.io.IOException;import java.util.ArrayList;import java.util.List; import javax.servlet.ServletException;import javax.servlet.annotation.WebServlet;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse; /** * 百度下拉框服務(wù)器端 */@WebServlet("/test")public class test extends HttpServlet {	private static final long serialVersionUID = 1L; 	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {		//獲取前端傳入的數(shù)據(jù)		String text = request.getParameter("text");		//我們?cè)谶@里也還是向list集合中添加數(shù)據(jù),模擬數(shù)據(jù)庫的查詢操作		System.out.println(text);		List<String> list =new ArrayList<>();		list.add("zhuxingyi");		list.add("zhuwei");		list.add("zhuyuanz");		list.add("zhude");				//將數(shù)據(jù) 轉(zhuǎn)換成字符串		String str = "";		if(text.startsWith("z")) {			for(int i=0;i<list.size();i++) {				if(i>0) {					str+=",";				}				str+=list.get(i);			}			//將處理好的數(shù)據(jù)傳回給客戶端			response.getWriter().write(str);		}			}  	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {		// TODO Auto-generated method stub		doGet(request, response);	} }

演示一下看看呢,(很尷尬,樓主還不會(huì)做gif圖呢,各位先看看靜態(tài)圖把。。。)

輸入‘z"試一試呢:

點(diǎn)擊一下試一試呢:

Ok了,這就是一個(gè)簡(jiǎn)單的模仿百度的搜索框啦,以上有不足的地方你一定要指出哦,謝謝。拜啦

以上這篇使用Ajax模仿百度搜索框的自動(dòng)提示功能實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持。

標(biāo)簽: Ajax
相關(guān)文章:
主站蜘蛛池模板: 一区二区三区在线 | 网站 | 美国毛片亚洲社区在线观看 | 亚洲一区成人 | 亚州精品一区二区三区 | 给我一个可以看片的www日本 | 美女张开腿让男人桶爽动漫视频 | 欧美国产成人精品一区二区三区 | 日韩中文在线 | 欧美成人免费xxx大片 | 欧美日韩高清在线观看一区二区 | 成人公开视频 | 国产成人在线免费视频 | 日韩精品一区二区三区中文在线 | 亚洲综合精品成人 | 亚洲爆爽 | 亚洲精品午夜 | 国产一级毛片大陆 | 韩国精品一区二区三区在线观看 | 91欧美在线视频 | 91精品视品在线播放 | 久久久精品久久久久三级 | 国产精品自在自线 | 国产一区二区在线播放 | 毛片网站在线播放 | 国产日韩欧美一区二区三区综合 | 日本女人在线观看 | 国内成人精品视频 | 欧美成人自拍 | 香港一级纯黄大片 | 日韩黄色视屏 | 中国嫩模一级毛片 | 波多野结衣中文在线 | 色网站在线 | 天天看片天天爽_免费播放 天天看夜夜 | 九色福利 | 成人午夜视频在线播放 | 欧美日韩99| a级毛片毛片免费观看永久 a级毛片毛片免费很很综合 | 97国产在线视频公开免费 | 免费人成黄页网站在线观看 | 日本在线免费观看视频 |