js實(shí)現(xiàn)搜索框關(guān)鍵字智能匹配代碼
只要使用搜索引擎的朋友應(yīng)該都有這樣的體會,就是當(dāng)在搜索框輸入關(guān)鍵字的時(shí)候,會出現(xiàn)自能匹配現(xiàn)象,這絕對是非常好的用戶體驗(yàn),下面就是一段類似的代碼,當(dāng)然這里只是掩飾,所以只能匹配的數(shù)據(jù)都是本地固定好的,在實(shí)際應(yīng)用中可以才能夠數(shù)據(jù)庫讀取數(shù)據(jù)。
效果圖:
代碼實(shí)例如下:
<!DOCTYPE html> <html> <head> <meta charset=" utf-8"> <meta name="author" content="http://www.softwhy.com/" /> <title>搜索框關(guān)鍵字智能匹配實(shí)例代碼</title> <style> body, ul, li { margin:0; padding:0; } body { font-size:12px; font-family:sumsun, arial; background:#FFFFFF; } .gover_search { position:relative; z-index:99; height:63px; padding:15px 0 0 20px; border:1px solid #b8cfe6; border-bottom:0; background:url(../images/gover_search_bg.gif) repeat-x 0 0; } .gover_search_form {height:36px;} .gover_search .search_t { float:left; width:112px; line-height:26px; color:#666; } .gover_search .input_search_key { float:left; width:462px; height:18px; padding:3px; margin-right:5px; border:1px solid #ccc; line-height:18px; background:#fff; } .gover_search .search_btn { float:left; width:68px; height:26px; overflow:hidden; border:1px solid #ccc; text-align:center; color:#ff3300; letter-spacing:5px; background:url(../images/gover_search_bg.gif) no-repeat 0 -79px; cursor:pointer; font-weight:bold; } .gover_search .search_suggest { position:absolute; z-index:999; left:132px; top:41px; width:468px; border:1px solid #ccc; border-top:none; display:none; color:#004080; } .gover_search .search_suggest li { height:24px; overflow:hidden; padding-left:3px; line-height:24px; background:#fff; cursor:default; } .gover_search .search_suggest li.hover {background:#ddd;} .num_right { float:right; text-align:right; line-height:24px; padding-right:10px } </style> </head> <body> <div class="gover_search"> <div class="gover_search_form clearfix"> <span class="search_t">關(guān)鍵詞匹配搜索</span> <input type="text" class="input_search_key" id="gover_search_key" placeholder="請輸入關(guān)鍵詞直接搜索" /> <button type="submit" class="search_btn">搜索</button> <div class="search_suggest" id="gov_search_suggest"> <ul> </ul> </div> </div> </div> <script type="text/javascript" src="http://www.softwhy.com/mytest/jQuery/jquery-1.8.3.js"></script> <script type="text/javascript"> function oSearchSuggest(searchFuc) { var input = $('#gover_search_key'); var suggestWrap = $('#gov_search_suggest'); var key = ""; var init = function(){ input.bind('keyup',sendKeyWord); input.bind('blur',function(){setTimeout(hideSuggest,100);}) } var hideSuggest = function(){ suggestWrap.hide(); } //發(fā)送請求,根據(jù)關(guān)鍵字到后臺查詢 var sendKeyWord = function(event){ //鍵盤選擇下拉項(xiàng) if(suggestWrap.css('display')=='block'&&event.keyCode == 38||event.keyCode == 40) { var current = suggestWrap.find('li.hover'); if(event.keyCode == 38) { if(current.length>0) { var prevLi = current.removeClass('hover').prev(); if(prevLi.length>0) { prevLi.addClass('hover'); input.val(prevLi.html()); } } else { var last = suggestWrap.find('li:last'); last.addClass('hover'); input.val(last.html()); } } else if(event.keyCode == 40) { if(current.length>0) { var nextLi = current.removeClass('hover').next(); if(nextLi.length>0) { nextLi.addClass('hover'); input.val(nextLi.html()); } } else { var first = suggestWrap.find('li:first'); first.addClass('hover'); input.val(first.html()); } } //輸入字符 } else { var valText = $.trim(input.val()); if(valText ==''||valText==key) { return; } searchFuc(valText); key = valText; } } //請求返回后,執(zhí)行數(shù)據(jù)展示 this.dataDisplay = function(data){ if(data.length<=0) { suggestWrap.hide(); return; } //往搜索框下拉建議顯示欄中添加條目并顯示 var li; var tmpFrag = document.createDocumentFragment(); suggestWrap.find('ul').html(''); for(var i=0; i<data.length; i++) { li = document.createElement('LI'); li.innerHTML = data[i]; tmpFrag.appendChild(li); } suggestWrap.find('ul').append(tmpFrag); suggestWrap.show(); //為下拉選項(xiàng)綁定鼠標(biāo)事件 suggestWrap.find('li').hover(function(){ suggestWrap.find('li').removeClass('hover'); $(this).addClass('hover'); },function(){ $(this).removeClass('hover'); }).bind('click',function(){ $(this).find("span").remove(); input.val(this.innerHTML); suggestWrap.hide(); }); } init(); }; //實(shí)例化輸入提示的JS,參數(shù)為進(jìn)行查詢操作時(shí)要調(diào)用的函數(shù)名 var searchSuggest = new oSearchSuggest(sendKeyWordToBack); //這是一個(gè)模似函數(shù),實(shí)現(xiàn)向后臺發(fā)送ajax查詢請求,并返回一個(gè)查詢結(jié)果數(shù)據(jù),傳遞給前臺的JS,再由前臺JS來展示數(shù)據(jù)。本函數(shù)由程序員進(jìn)行修改實(shí)現(xiàn)查詢的請求 //參數(shù)為一個(gè)字符串,是搜索輸入框中當(dāng)前的內(nèi)容 function sendKeyWordToBack(keyword){ var aData = []; aData.push('<span class="num_right">約100個(gè)</span>'+keyword+'返回?cái)?shù)據(jù)1'); aData.push('<span class="num_right">約200個(gè)</span>'+keyword+'返回?cái)?shù)據(jù)2'); aData.push('<span class="num_right">約100個(gè)</span>'+keyword+'返回?cái)?shù)據(jù)3'); aData.push('<span class="num_right">約50000個(gè)</span>'+keyword+'返回?cái)?shù)據(jù)4'); aData.push('<span class="num_right">約1044個(gè)</span>'+keyword+'2012是真的'); aData.push('<span class="num_right">約100個(gè)</span>'+keyword+'2012是假的'); aData.push('<span class="num_right">約100個(gè)</span>'+keyword+'2012是真的'); aData.push('<span class="num_right">約100個(gè)</span>'+keyword+'2012是假的'); //將返回的數(shù)據(jù)傳遞給實(shí)現(xiàn)搜索輸入框的輸入提示js類 searchSuggest.dataDisplay(aData); } </script> </body> </html>
更多關(guān)于搜索功能的文章請查看專題《JavaScript搜索功能匯總》
希望本文所述對大家學(xué)習(xí)javascript程序設(shè)計(jì)有所幫助。
- 基于Vue.js實(shí)現(xiàn)簡單搜索框
- JavaScript實(shí)現(xiàn)搜索框的自動完成功能(一)
- JS實(shí)現(xiàn)仿google、百度搜索框輸入信息智能提示的實(shí)現(xiàn)方法
- JavaScript實(shí)現(xiàn)百度搜索框效果
- JS+Ajax實(shí)現(xiàn)百度智能搜索框
- 自動完成的搜索框javascript實(shí)現(xiàn)
- JS實(shí)現(xiàn)京東首頁之頁面頂部、Logo和搜索框功能
- JS實(shí)現(xiàn)微信彈出搜索框 多條件查詢功能
- javascript搜索框效果實(shí)現(xiàn)方法
- JavaScript仿京東搜索框?qū)嵗?/a>
相關(guān)文章
JavaScript實(shí)現(xiàn)梯形乘法表的方法
這篇文章主要介紹了JavaScript實(shí)現(xiàn)梯形乘法表的方法,涉及基本javascript結(jié)合表格操作的技巧,需要的朋友可以參考下2015-04-04基于js實(shí)現(xiàn)判斷瀏覽器類型代碼實(shí)例
這篇文章主要介紹了基于js實(shí)現(xiàn)判斷瀏覽器類型代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07JavaScript將當(dāng)前時(shí)間轉(zhuǎn)換成UTC標(biāo)準(zhǔn)時(shí)間的方法
這篇文章主要介紹了JavaScript將當(dāng)前時(shí)間轉(zhuǎn)換成UTC標(biāo)準(zhǔn)時(shí)間的方法,涉及javascript中Date及toUTCString方法的使用技巧,需要的朋友可以參考下2015-04-04微信小程序?qū)崿F(xiàn)元素漸入漸出動畫效果封裝方法
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)元素漸入漸出動畫效果封裝方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05