使用Ajax模仿百度搜索框的自動(dòng)提示功能實(shí)例
啊啊,熬夜了。今天學(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.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對(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ù)庫(kù)的查詢操作 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è)參考,也希望大家多多支持我們。
欄 目:AJAX相關(guān)
本文標(biāo)題:使用Ajax模仿百度搜索框的自動(dòng)提示功能實(shí)例
本文地址:http://mengdiqiu.com.cn/a1/AJAXxiangguan/11279.html
您可能感興趣的文章
- 01-11ajax請(qǐng)求后臺(tái)得到j(luò)son數(shù)據(jù)后動(dòng)態(tài)生成樹形下拉框的方法
- 01-11layui的checbox在Ajax局部刷新下的設(shè)置方法
- 01-11ajax獲得json對(duì)象數(shù)組 循環(huán)輸出數(shù)據(jù)的方法
- 01-11解決ajax請(qǐng)求后臺(tái),有時(shí)收不到返回值的問題
- 01-11詳談ajax返回?cái)?shù)據(jù)成功 卻進(jìn)入error的方法
- 01-11解決AJAX返回狀態(tài)200沒有調(diào)用success的問題
- 01-11快速解決ajax返回值給外部函數(shù)的問題
- 01-11Ajax實(shí)現(xiàn)動(dòng)態(tài)顯示并操作表信息的方法
- 01-11ajax實(shí)現(xiàn)從后臺(tái)拿數(shù)據(jù)顯示在HTML前端的方法
- 01-11ajax動(dòng)態(tài)查詢數(shù)據(jù)庫(kù)數(shù)據(jù)并顯示在前臺(tái)的方法


閱讀排行
- 1C語言 while語句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
- 3利用C語言實(shí)現(xiàn)“百馬百擔(dān)”問題方法
- 4C語言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 01-11layui的checbox在Ajax局部刷新下的設(shè)置方
- 01-11ajax請(qǐng)求后臺(tái)得到j(luò)son數(shù)據(jù)后動(dòng)態(tài)生成樹
- 01-11ajax獲得json對(duì)象數(shù)組 循環(huán)輸出數(shù)據(jù)的
- 01-11解決ajax請(qǐng)求后臺(tái),有時(shí)收不到返回值的
- 01-11詳談ajax返回?cái)?shù)據(jù)成功 卻進(jìn)入error的方
- 01-11解決AJAX返回狀態(tài)200沒有調(diào)用success的問
- 01-11快速解決ajax返回值給外部函數(shù)的問題
- 01-11Ajax實(shí)現(xiàn)動(dòng)態(tài)顯示并操作表信息的方法
- 01-11ajax實(shí)現(xiàn)從后臺(tái)拿數(shù)據(jù)顯示在HTML前端的
- 01-11ajax動(dòng)態(tài)查詢數(shù)據(jù)庫(kù)數(shù)據(jù)并顯示在前臺(tái)
隨機(jī)閱讀
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-10C#中split用法實(shí)例總結(jié)
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 04-02jquery與jsp,用jquery
- 01-11ajax實(shí)現(xiàn)頁面的局部加載
- 01-10delphi制作wav文件的方法
- 01-10使用C語言求解撲克牌的順子及n個(gè)骰子
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什