仿百度的關(guān)鍵詞匹配搜索示例
更新時(shí)間:2013年09月25日 16:48:59 作者:
關(guān)鍵詞匹配搜索想必大家一定會想到百度,下面有個(gè)不錯(cuò)的示例,感興趣的朋友可以參考下
復(fù)制代碼 代碼如下:
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>關(guān)鍵詞匹配搜索仿百度</title>
<meta name="description" content=" 內(nèi)容介紹不超過100個(gè)中文">
<meta name="keywords" content=" 內(nèi)容相關(guān)關(guān)鍵詞3-5個(gè)">
<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://jt.875.cn/js/jquery.js"></script>
<script type="text/javascript">
//實(shí)現(xiàn)搜索輸入框的輸入提示js類
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 obj = {
"keyword" : keyword
};
$.ajax({
type: "POST",
url: "${ctx}/front/suqiu2/search/prompt-keyword.action",
async:false,
data: obj,
dataType: "json",
success: function(data){
//var json = eval("("+data+")");
var key=data.split(",");
var aData = [];
for(var i=0;i<key.length;i++){
//以下為根據(jù)輸入返回搜索結(jié)果的模擬效果代碼,實(shí)際數(shù)據(jù)由后臺返回
if(key[i]!=""){
aData.push(key[i]);
}
}
//將返回的數(shù)據(jù)傳遞給實(shí)現(xiàn)搜索輸入框的輸入提示js類
searchSuggest.dataDisplay(aData);
}
}); */
//以下為根據(jù)輸入返回搜索結(jié)果的模擬效果代碼,實(shí)際數(shù)據(jù)由后臺返回
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>
您可能感興趣的文章:
- python通過BF算法實(shí)現(xiàn)關(guān)鍵詞匹配的方法
- js實(shí)現(xiàn)帶搜索功能的下拉框?qū)崟r(shí)搜索實(shí)時(shí)匹配
- JS仿百度搜索自動(dòng)提示框匹配查詢功能
- Java/Js下使用正則表達(dá)式匹配嵌套Html標(biāo)簽
- js 正則表達(dá)式學(xué)習(xí)筆記之匹配字符串
- js正則表達(dá)式之$1$2$3$4$5$6$7$8$9屬性,返回子匹配的結(jié)果
- js正則表達(dá)式匹配數(shù)字字母下劃線等
- JS 正則表達(dá)式(學(xué)習(xí)筆記2)匹配網(wǎng)址url參數(shù)
- js 獲取中文拼音,Select自動(dòng)匹配字母獲取值的代碼
- 1秒50萬字!js實(shí)現(xiàn)關(guān)鍵詞匹配
相關(guān)文章
jquery處理頁面彈出層查詢數(shù)據(jù)等待操作實(shí)例
這篇文章主要介紹了jquery處理頁面彈出層查詢數(shù)據(jù)等待操作,實(shí)例分析了jquery實(shí)現(xiàn)等待效果的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03Jquery+ajax+JAVA(servlet)實(shí)現(xiàn)下拉菜單異步取值
這篇文章主要介紹了Jquery+ajax+JAVA(servlet)實(shí)現(xiàn)下拉菜單異步取值的相關(guān)資料,需要的朋友可以參考下2016-03-03jquery通過load獲取文件的內(nèi)容并跳到錨點(diǎn)的方法
這篇文章主要介紹了jquery通過load獲取文件的內(nèi)容并跳到錨點(diǎn)的方法,涉及l(fā)oad及animate等方法的使用技巧,需要的朋友可以參考下2015-01-01基于Jquery的實(shí)現(xiàn)回車鍵Enter切換焦點(diǎn)
系統(tǒng)默認(rèn)情況下,使用Tab按鍵切換頁面元素的焦點(diǎn),有沒有想過回車鍵Enter也可以實(shí)現(xiàn)這種功能,并且具有良好的用戶體驗(yàn)。2010-09-09jQuery中setTimeout的幾種使用方法小結(jié)
jQuery 中 setTimeout/setInterval 不能像在原生態(tài) javascript 中那樣使用, 否則會報(bào)錯(cuò).2013-04-04