使用AJAX異步通信技術(shù)實現(xiàn)搜索聯(lián)想和自動補全示例
目錄

一:ajax實現(xiàn)搜索聯(lián)想和自動補全

(1)實現(xiàn)的原理

什么是搜索聯(lián)想?自動補全?

①百度是一個很典型的代表。在百度的搜索框中輸入相關(guān)信息的時候,會有搜索聯(lián)想以及自動補全。

②搜索聯(lián)想和自動補全:實際上是為了方便用戶的使用,讓用戶的體驗更好。

③搜索聯(lián)想:當用戶輸入一些單詞之后,自動聯(lián)想出用戶要搜索的信息,給一個提示。

④自動補全:當聯(lián)想出一些內(nèi)容之后,用戶點擊某個聯(lián)想的單詞,然后將這個單詞自動補全到搜索框當中。

⑤搜索聯(lián)想和自動補全功能,因為是頁面局部刷新效果,所以需要使用ajax請求來完成。

搜索聯(lián)想,自動補全功能的核心實現(xiàn)原理?

①當鍵盤事件發(fā)生之后,比如keyup:鍵彈起事件。

②會發(fā)送ajax請求,請求中提交用戶輸入的搜索內(nèi)容,例如:北京(發(fā)送ajax請求,攜帶“北京”兩個字)。

③后端接收到ajax請求,接收到“北京”兩個字,執(zhí)行select語句進行模糊查詢,返回查詢結(jié)果

④將查詢結(jié)果封裝成json格式的字符串,將json格式的字符串響應(yīng)到前端。

⑤前端接收到j(luò)son格式的字符串之后,解析這個json字符串,動態(tài)展示頁面。 

(2)頁面實現(xiàn)

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>ajax實現(xiàn)搜索聯(lián)想和自動補全功能</title>
    <style type="text/css">
        /* 類選擇器,設(shè)置input標簽,text邊框*/
        .userinput {
            width: 300px; /*框?qū)?/
            height: 25px; /*框高*/
            font-size: 20px; /*里面字大小*/
            padding-left: 5px; /*內(nèi)補丁,距離框的距離*/
        }
        /*類選擇器,設(shè)置div的樣式*/
        .showdatadiv {
            width: 309px; /*寬度*/
            border: 1px solid lightgray; /*實線邊框*/
            background-color: antiquewhite; /*設(shè)置背景顏色*/
            display: none; /*設(shè)置開始的div是隱藏的,不顯示*/
        }
        /*設(shè)置p標簽*/
        .showdatadiv p {
            padding-left: 5px; /*內(nèi)補丁,距離框的距離*/
            margin-top: 2px; /*外補丁,p距離頂部的寬度*/
            margin-bottom: 2px; /*外補丁,p距離低部的寬度*/
        }
        /*p標簽增加動作,點到其中一個選項變色并變成小手*/
        .showdatadiv p:hover {
            cursor: pointer; /*鼠標變成小手*/
            border: 1px blue solid; /*每選中一行,增加實線邊框*/
            background-color: aliceblue; /*設(shè)置變換的背景色*/
        }
    </style>
</head>
<body>
<!--文本框-->
<input type="text" class="userinput" id="keywords">
<!--div盒子-->
<div id="datadiv" class="showdatadiv">
<!--<p>北京疫情最新情況</p>
    <p>北京天氣</p>
    <p>北京時間</p>
    <p>北京人</p>-->
</div>
</body>
</html>

頁面展示

(3)設(shè)置數(shù)據(jù)庫表

drop table if exists t_ajax;
create table t_ajax(
    id int primary key auto_increment,
    content varchar(255)
);
insert into t_ajax(content) values('javascript');
insert into t_ajax(content) values('javaweb');
insert into t_ajax(content) values('java');
insert into t_ajax(content) values('java123');
insert into t_ajax(content) values('mysql');
insert into t_ajax(content) values('myweb');
insert into t_ajax(content) values('myapp');
insert into t_ajax(content) values('jdk');
commit;
select * from t_ajax;

效果展示 

(4)前端代碼實現(xiàn)

①只要keyup鍵盤事件發(fā)生,就發(fā)送ajax請求,把輸入的數(shù)據(jù)(this.value)發(fā)送出去

②首先就要連接數(shù)據(jù)庫進行模糊查詢,實現(xiàn)搜索聯(lián)想功能

③然后我們點擊div的<p>標簽的內(nèi)容時,會進行自動補全到文本框

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>ajax實現(xiàn)搜索聯(lián)想和自動補全功能</title>
    <style type="text/css">
        /* 類選擇器,設(shè)置input標簽,text邊框*/
        .userinput {
            width: 300px; /*框?qū)?/
            height: 25px; /*框高*/
            font-size: 20px; /*里面字大小*/
            padding-left: 5px; /*內(nèi)補丁,距離框的距離*/
        }
        /*類選擇器,設(shè)置div的樣式*/
        .showdatadiv {
            width: 309px; /*寬度*/
            border: 1px solid lightgray; /*實線邊框*/
            background-color: antiquewhite; /*設(shè)置背景顏色*/
            display: none; /*設(shè)置開始的div是隱藏的,不顯示*/
        }
        /*設(shè)置p標簽*/
        .showdatadiv p {
            padding-left: 5px; /*內(nèi)補丁,距離框的距離*/
            margin-top: 2px; /*外補丁,p距離頂部的寬度*/
            margin-bottom: 2px; /*外補丁,p距離低部的寬度*/
        }
        /*p標簽增加動作,點到其中一個選項變色并變成小手*/
        .showdatadiv p:hover {
            cursor: pointer; /*鼠標變成小手*/
            border: 1px blue solid; /*每選中一行,增加實線邊框*/
            background-color: aliceblue; /*設(shè)置變換的背景色*/
        }
    </style>
</head>
<body>
<script type="text/javascript">
    window.onload = function() {
        document.getelementbyid("keywords").onkeyup = function(){
            if (this.value == "") {
                // 如果為空串,就把div隱藏起來
                // 不然查詢聯(lián)想之后,刪除查詢的內(nèi)容,下面div還是保持原狀
                document.getelementbyid("datadiv").style.display = "none"
            }else{
                // 發(fā)送ajax請求
                // 1. 創(chuàng)建ajax核心對象
                var xmlhttprequest = new xmlhttprequest();
                // 2. 注冊回調(diào)函數(shù)
                xmlhttprequest.onreadystatechange = function() {
                    if (xmlhttprequest.readystate == 4) {
                        if (xmlhttprequest.status >= 200 && xmlhttprequest.status < 300) {
                            // [{"content":"javascript"},{"content":"javaweb"},{"content":"java..."}]
                            var json = json.parse(xmlhttprequest.responsetext);
                            // 遍歷數(shù)組
                            var html = ""
                            for (var i = 0; i < json.length; i++) {
                                // 點擊p標簽執(zhí)行一個回調(diào)函數(shù),把內(nèi)容顯示到文本框中
                                html += "<p onclick='setinput(\""+json[i].content+"\")'>"+json[i].content+"</p>"
                            }
                            // 讓數(shù)據(jù)在div展示出來
                            document.getelementbyid("datadiv").innerhtml = html
                            // 讓div顯示出來
                            document.getelementbyid("datadiv").style.display = "block"
                        }
                    }
                }
                // 3. 開啟通道,并把數(shù)據(jù)傳過去,連接數(shù)據(jù)庫進行模糊查詢
                xmlhttprequest.open("get", "/auto_complete/query?_="+new date().gettime()+"&keywords=" + this.value, true)
                // 4. 發(fā)送請求
                xmlhttprequest.send()
            }
        }
    }
    // 實現(xiàn)自動補全功能
    function setinput(content){
        // 先把數(shù)據(jù)顯示到文本框中
        document.getelementbyid("keywords").value = content
        // 顯示到文本框后,再次把div進行隱藏
        document.getelementbyid("datadiv").style.display = "none"
    }
</script>
<!--文本框-->
<input type="text" class="userinput" id="keywords">
<!--div盒子-->
<div id="datadiv" class="showdatadiv">
    <!--<p>北京疫情最新情況</p>
    <p>北京天氣</p>
    <p>北京時間</p>
    <p>北京人</p>-->
</div>
</body>
</html>

(5)后端代碼實現(xiàn)

主要是根據(jù)發(fā)過來的數(shù)據(jù),連接數(shù)據(jù)庫進行模糊查詢;把查詢結(jié)果拼成json格式的字符串

package com.bjpowernode.zl;
import javax.servlet.servletexception;
import javax.servlet.annotation.webservlet;
import javax.servlet.http.httpservlet;
import javax.servlet.http.httpservletrequest;
import javax.servlet.http.httpservletresponse;
import java.io.ioexception;
import java.sql.*;
import java.util.arraylist;
import java.util.list;
@webservlet("/query")
public class queryservlet extends httpservlet {
    @override
    protected void doget(httpservletrequest request, httpservletresponse response)
            throws servletexception, ioexception {
        // 獲取用戶輸入的關(guān)鍵字
        string keywords = request.getparameter("keywords");
        // jdbc代碼連接數(shù)據(jù)庫,根據(jù)關(guān)鍵字查詢數(shù)據(jù)庫,返回數(shù)據(jù),拼接json格式的字符串
        connection conn = null;
        preparedstatement ps = null;
        resultset rs = null;
        // 拼成json格式的字符串
        stringbuilder sb = new stringbuilder();
        sb.append("[");
        try {
            // 注冊驅(qū)動
            class.forname("com.mysql.jdbc.driver");
            // 獲取連接
            string url = "jdbc:mysql://localhost:3306/bjpowernode?useunicode=true&characterencoding=utf-8";
            string user = "root";
            string password = "***";
            conn = drivermanager.getconnection(url, user, password);
            string sql = "select content from t_ajax where content like ?"; // 模糊查詢的時候,條件不建議使用%開始,因為會讓字段上的索引失效,查詢效率降低。
            ps = conn.preparestatement(sql);
            ps.setstring(1, keywords + "%");
            rs = ps.executequery();
            // [{"content":"javascript"},{"content":"javaweb"},{"content":"java..."}]
            while (rs.next()) {
                string content = rs.getstring("content");
                sb.append("{\"content\":\""+content+"\"},");
            }
        }catch(exception e){
            e.printstacktrace();
        } finally {
            if (conn != null) {
                try {
                    conn.close();
                } catch (sqlexception e) {
                    e.printstacktrace();
                }
            }
            if (ps != null) {
                try {
                    ps.close();
                } catch (sqlexception e) {
                    e.printstacktrace();
                }
            }
            if (rs != null) {
                try {
                    rs.close();
                } catch (sqlexception e) {
                    e.printstacktrace();
                }
            }
        }
        // 最后會多一個逗號,進行截串
        response.setcontenttype("text/html;charset=utf-8");
        response.getwriter().print(sb.subsequence(0, sb.length() - 1) + "]");
    }
}

(6)動圖效果展示 

二:http狀態(tài)信息

1xx: 信息

消息:描述:100 continue服務(wù)器僅接收到部分請求,但是一旦服務(wù)器并沒有拒絕該請求,客戶端應(yīng)該繼續(xù)發(fā)送其余的請求。101 switching protocols服務(wù)器轉(zhuǎn)換協(xié)議:服務(wù)器將遵從客戶的請求轉(zhuǎn)換到另外一種協(xié)議。

2xx: 成功

消息:描述:200 ok請求成功(其后是對get和post請求的應(yīng)答文檔。)201 created請求被創(chuàng)建完成,同時新的資源被創(chuàng)建。202 accepted供處理的請求已被接受,但是處理未完成。203 non-authoritative information文檔已經(jīng)正常地返回,但一些應(yīng)答頭可能不正確,因為使用的是文檔的拷貝。204 no content沒有新文檔。瀏覽器應(yīng)該繼續(xù)顯示原來的文檔。如果用戶定期地刷新頁面,而servlet可以確定用戶文檔足夠新,這個狀態(tài)代碼是很有用的。205 reset content沒有新文檔。但瀏覽器應(yīng)該重置它所顯示的內(nèi)容。用來強制瀏覽器清除表單輸入內(nèi)容。206 partial content客戶發(fā)送了一個帶有range頭的get請求,服務(wù)器完成了它。

3xx: 重定向

消息:描述:300 multiple choices多重選擇。鏈接列表。用戶可以選擇某鏈接到達目的地。最多允許五個地址。301 moved permanently所請求的頁面已經(jīng)轉(zhuǎn)移至新的url。302 found所請求的頁面已經(jīng)臨時轉(zhuǎn)移至新的url。303 see other所請求的頁面可在別的url下被找到。304 not modified未按預(yù)期修改文檔??蛻舳擞芯彌_的文檔并發(fā)出了一個條件性的請求(一般是提供if-modified-since頭表示客戶只想比指定日期更新的文檔)。服務(wù)器告訴客戶,原來緩沖的文檔還可以繼續(xù)使用。305 use proxy客戶請求的文檔應(yīng)該通過location頭所指明的代理服務(wù)器提取。306 unused此代碼被用于前一版本。目前已不再使用,但是代碼依然被保留。307 temporary redirect被請求的頁面已經(jīng)臨時移至新的url。

4xx: 客戶端錯誤

消息:描述:400 bad request服務(wù)器未能理解請求。401 unauthorized被請求的頁面需要用戶名和密碼。402 payment required此代碼尚無法使用。403 forbidden對被請求頁面的訪問被禁止。404 not found服務(wù)器無法找到被請求的頁面。405 method not allowed請求中指定的方法不被允許。406 not acceptable服務(wù)器生成的響應(yīng)無法被客戶端所接受。407 proxy authentication required用戶必須首先使用代理服務(wù)器進行驗證,這樣請求才會被處理。408 request timeout請求超出了服務(wù)器的等待時間。409 conflict由于沖突,請求無法被完成。410 gone被請求的頁面不可用。411 length required"content-length" 未被定義。如果無此內(nèi)容,服務(wù)器不會接受請求。412 precondition failed請求中的前提條件被服務(wù)器評估為失敗。413 request entity too large由于所請求的實體的太大,服務(wù)器不會接受請求。414 request-url too long由于url太長,服務(wù)器不會接受請求。當post請求被轉(zhuǎn)換為帶有很長的查詢信息的get請求時,就會發(fā)生這種情況。415 unsupported media type由于媒介類型不被支持,服務(wù)器不會接受請求。416服務(wù)器不能滿足客戶在請求中指定的range頭。417 expectation failed

5xx: 服務(wù)器錯誤

消息:描述:500 internal server error請求未完成。服務(wù)器遇到不可預(yù)知的情況。501 not implemented請求未完成。服務(wù)器不支持所請求的功能。502 bad gateway請求未完成。服務(wù)器從上游服務(wù)器收到一個無效的響應(yīng)。503 service unavailable請求未完成。服務(wù)器臨時過載或當機。504 gateway timeout網(wǎng)關(guān)超時。505 http version not supported服務(wù)器不支持請求中指明的http協(xié)議版本。

到此這篇關(guān)于使用ajax異步通信技術(shù)實現(xiàn)搜索聯(lián)想和自動補全示例的文章就介紹到這了,更多相關(guān)ajax實現(xiàn)搜索聯(lián)想和自動補全內(nèi)容請搜索碩編程以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持碩編程!

相關(guān)文章
亚洲国产精品第一区二区,久久免费视频77,99V久久综合狠狠综合久久,国产免费久久九九免费视频