濮阳杆衣贸易有限公司

主頁 > 知識庫 > 使用Ajax模仿百度搜索框的自動提示功能實例

使用Ajax模仿百度搜索框的自動提示功能實例

熱門標(biāo)簽:廣西智能外呼系統(tǒng)多少錢 銷售電銷機(jī)器人詐騙 地圖標(biāo)注與公司業(yè)務(wù)關(guān)系 福建微碼電話機(jī)器人 平?jīng)龈叩碌貓D標(biāo)注商戶要收費(fèi)嗎 荊州智能電銷機(jī)器人 大學(xué)校門地圖標(biāo)注 提高電話機(jī)器人接通率 外呼系統(tǒng)api對接

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

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

來我們寫一個簡陋的jsp頁面 Look! 是這個樣子的

下面是代碼:

%@ page language="java" contentType="text/html; charset=UTF-8"
 pageEncoding="UTF-8"%>
!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.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" style="display: none; 
  	width: 171px; border: 1px solid pink";>
  /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對象
 				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;
 							}
 							//我們將會在服務(wù)器端把數(shù)據(jù)用 , 隔開,當(dāng)然這里也可以使用json
 							var result = str.split(",");
 							var childs = "";
 							//遍歷結(jié)果集,將結(jié)果集中的每一條數(shù)據(jù)用一個div顯示,把所有的div放入到childs中
 							for(var i=0; iresult.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)懸停時改變div的顏色
 		function changeColorwhenMouseover(div){
 			div.style.backgroundColor="pink";
 		}
 		//鼠標(biāo)移出時回復(fù)div顏色
 		function recoverColorwhenMouseout(div){
 			div.style.backgroundColor="";
 		}
 		//當(dāng)鼠標(biāo)帶點擊div時,將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");
		//我們在這里也還是向list集合中添加數(shù)據(jù),模擬數(shù)據(jù)庫的查詢操作
		System.out.println(text);
		ListString> 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;ilist.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);
	}
 
}

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

輸入‘z'試一試呢:

點擊一下試一試呢:

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

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

您可能感興趣的文章:
  • php+ajax做仿百度搜索下拉自動提示框(有實例)
  • Servlet+Ajax實現(xiàn)智能搜索框智能提示功能
  • AJax實現(xiàn)類似百度搜索欄的功能 (面試多見)
  • Ajax實現(xiàn)搜索引擎自動補(bǔ)全功能

標(biāo)簽:樂山 海南 內(nèi)江 婁底 衡陽 邯鄲 德陽 黔東

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《使用Ajax模仿百度搜索框的自動提示功能實例》,本文關(guān)鍵詞  使用,Ajax,模仿,百度,搜索,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《使用Ajax模仿百度搜索框的自動提示功能實例》相關(guān)的同類信息!
  • 本頁收集關(guān)于使用Ajax模仿百度搜索框的自動提示功能實例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    汾阳市| 广元市| 锦屏县| 明水县| 南川市| 攀枝花市| 克东县| 依安县| 莒南县| 广德县| 云安县| 资源县| 双鸭山市| 赤水市| 土默特左旗| 莆田市| 常宁市| 英超| 阳泉市| 宁河县| 常宁市| 长治市| 乌审旗| 陵水| 长汀县| 丹巴县| 海原县| 钟山县| 静乐县| 涞水县| 福州市| 行唐县| 珠海市| 调兵山市| 剑河县| 高陵县| 常宁市| 昌吉市| 阜城县| 榆社县| 肃北|