JS實(shí)現(xiàn)搜索關(guān)鍵詞的智能提示功能
最近在百度搜索的時(shí)候,當(dāng)你輸入一個(gè)字或者詞的時(shí)候,他會(huì)給你們彈出一個(gè)下拉框出來,里面是和你相關(guān)的搜索提示
比如 我輸入楊字,他會(huì)給我提示以下搜索提示
我嘗試著用JavaScript做了一個(gè)類似的練習(xí),以下是我用VS2013寫的代碼,有不對的地方,請不吝賜教。
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title></title> <script type="text/javascript"> onload = function () { function handle() { var keyWords = { "楊忠科": ["楊忠科的視頻", "楊忠科的微博", "楊忠科的郵箱"], "楊": ["楊利偉", "楊振宇", "楊過"], "楊忠": ["楊忠科", "楊忠學(xué)", "楊忠愛國"], "楊忠科愛":["楊忠科愛祖國","楊忠科愛首都","楊忠科愛學(xué)習(xí)"] }; if (keyWords[this.value]) { //判斷body中是否有這個(gè)層,如果有就刪掉了 if (document.getElementById('dv')) { document.body.removeChild(document.getElementById('dv')); } //開始創(chuàng)建層 var dvObj = document.createElement('div'); dvObj.id = 'dv'; dvObj.style.width = '300px'; //dvObj.style.height = '200px'; //將來可以不要 dvObj.style.border = '1px solid red'; document.body.appendChild(dvObj); //脫離文檔流 dvObj.style.position = 'absolute'; dvObj.style.left = this.offsetLeft + 'px'; dvObj.style.top = this.offsetHeight + this.offsetTop + 'px'; //循環(huán)創(chuàng)建 for (var i = 0; i < keyWords[this.value].length; i++) { //創(chuàng)建一個(gè)可以存文本的標(biāo)簽 var pObj = document.createElement('p'); pObj.innerText = keyWords[this.value][i]; //p標(biāo)簽要有小手,還有高亮顯示 pObj.style.cursor = 'pointer'; pObj.style.margin = '5px'; pObj.onmouseover = function () { this.style.backgroundColor = 'red'; }; pObj.onmouseout = function () { this.style.backgroundColor = ''; } dvObj.appendChild(pObj); //把p標(biāo)簽加到層中 } //創(chuàng)建可以顯示文件的標(biāo)簽 } } //firefox下檢測狀態(tài)改變只能用oninput,且需要用addEventListener來注冊事件。 if (/msie/i.test(navigator.userAgent)) //ie瀏覽器 { document.getElementById('txt').onpropertychange = handle } else {//非ie瀏覽器,比如Firefox document.getElementById('txt').addEventListener("input", handle, false); } }; </script> </head> <body> <span id="msg"></span> 請輸入搜索關(guān)鍵字<input type="text" name="name" value="" style="width:300px;height:30px;font-size:25px; border:1px solid green" id="txt"/>百度一下 </body> </html>
效果展示:
關(guān)于這個(gè)練習(xí)我有以下幾點(diǎn)思索
1.因?yàn)樗阉鳠嵩~提前被設(shè)定好,放在鍵值對里面,所以搜索的范圍也就被限定了,這個(gè)可以再被加深,和數(shù)據(jù)庫中的數(shù)據(jù)連接起來,搜索的的關(guān)鍵詞直接從數(shù)據(jù)庫中查詢,這個(gè)具體怎么寫我還沒研究透,希望有經(jīng)驗(yàn)的前輩可以指教。
2.關(guān)于這個(gè)代碼的應(yīng)用我覺得可以應(yīng)用在用戶查詢搜索上,百度搜索就是一個(gè)很好的實(shí)例
3.代碼畢竟是JS寫的,如果用戶的電腦將JS控件阻止了,效果也就不行了。
以上所述是小編給大家介紹的JS實(shí)現(xiàn)搜索關(guān)鍵詞的智能提示功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
離開當(dāng)前頁面前使用js判斷條件提示是否要離開頁面
這篇文章主要介紹了離開當(dāng)前頁面前如何使用js判斷條件提示是否要離開頁面,需要的朋友可以參考下2014-05-05Javascript this 的一些學(xué)習(xí)總結(jié)
相信有C++、C#或Java等編程經(jīng)驗(yàn)的各位,對于this關(guān)鍵字再熟悉不過了。由于Javascript是一種面向?qū)ο蟮木幊陶Z言,它和C++、C#或Java一樣都包含this關(guān)鍵字,接下來我們將向大家介紹Javascript中的this關(guān)鍵字2012-08-08JavaScript實(shí)現(xiàn)的數(shù)字與字符串轉(zhuǎn)換功能示例
這篇文章主要介紹了JavaScript實(shí)現(xiàn)的數(shù)字與字符串轉(zhuǎn)換功能,涉及javascript數(shù)字、字符串等運(yùn)算與轉(zhuǎn)換相關(guān)操作技巧,需要的朋友可以參考下2017-08-08JavaScript基于遍歷操作實(shí)現(xiàn)對象深拷貝功能示例
這篇文章主要介紹了JavaScript基于遍歷操作實(shí)現(xiàn)對象深拷貝功能,涉及javascript元素遍歷與屬性操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2019-03-03js console.log打印對象時(shí)屬性缺失的解決方法
在編寫代碼時(shí),我們常常用 console.log() 的方式將信息在控制臺(tái)中打印出來以幫助我們進(jìn)行前端調(diào)試,那么console.log打印對象時(shí)屬性缺失怎么辦?下面我們就一起來了解一下解決方法2019-05-05小程序獲取用戶信息的兩種方法詳解(getUserProfile和頭像昵稱填寫)
小程序獲取用戶信息這部分其實(shí)不難,但是,他有點(diǎn)麻煩,下面這篇文章主要給大家介紹了關(guān)于小程序獲取用戶信息的兩種方法,主要使用的是getUserProfile和頭像昵稱填寫這兩種方法,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08在WordPress中加入Google搜索功能的簡單步驟講解
這篇文章主要介紹了在WordPress中加入Google搜索的簡單步驟講解,谷歌搜索很有用,但同時(shí)也要注意在國內(nèi)使用cse的連通性,需要的朋友可以參考下2016-01-01