摘要:當(dāng)按鈕被松開時(shí),觸發(fā)事件獲取到關(guān)鍵字判斷關(guān)鍵字是否為空若輸入字符串不為空則顯示網(wǎng)絡(luò)請(qǐng)求搜索。顯示自動(dòng)提示框,給框里填關(guān)聯(lián)詞條的內(nèi)容給緩存對(duì)象賦值若輸入字符串為空則顯示歷史搜索。
????最近項(xiàng)目一直在迭代更新,沒(méi)有什么新的東西做,所以拿出來(lái)一個(gè)搜索的小模塊分享下,功能就是輸入關(guān)鍵字能出來(lái)相關(guān)字的聯(lián)想吧,刪除一些字的時(shí)候順帶可以保存上一段的聯(lián)想,從外觀上來(lái)看,效果還罷了,這里分享給大家,可以供大家看看。
????效果圖如下,github鏈接在此search_demo
按照老規(guī)矩,下面就直接寫編寫過(guò)程了
第一步:創(chuàng)建文件
????創(chuàng)建相應(yīng)的html,js,css文件,引入jquery。
第二步:引入文件,設(shè)置meta,編寫html以及樣式
html:
搜索 取消歷史搜索
css:
*{ margin: 0; padding: 0; } body{ background-color: #f5f5f9; } .search_nav{ width: 100%; height: 45px; position: fixed; top:0; left: 0; background-color: #20232b; } .search_input{ float: left; width: 75%; height: 35px; margin-left: 30px; margin-top: 5px; font-size: 15px; text-indent: 30px; border: 1px solid black; border-radius: 40px; outline: none; } input::-webkit-search-cancel-button {display: none;} .search_cancel{ float: right; width: 15%; height: 100%; color:white; text-align: center; line-height: 45px; } .search_find{ background:#fff; line-height:42px; margin-top: 45px; } .search_history{ padding-left:10px; font-weight:700; font-size:16px } .search_find_title{ display:block; position:relative; padding-left:15px; padding-right:10px; font-size:14px; color:#8a8a8a; width:100%; box-sizing:border-box } .search_find_title:after{ content:""; position:absolute; top:0; left:15px; box-sizing:border-box; width:92%; height:1px; color:#ffffd; border-bottom:1px solid #ffffd; -webkit-transform-origin:0 0; transform-origin:0 0; -webkit-transform:scaleY(.4); transform:scaleY(.4) }
????當(dāng)然了,這里面的樣式格局什么的在自己實(shí)際項(xiàng)目中需要根據(jù)自己的項(xiàng)目來(lái)調(diào)整,不需要跟我這寫的一樣,重要的是邏輯部分。
第三步:編寫js邏輯
????一般情況下,我們?cè)谶M(jìn)入搜索頁(yè)面的時(shí)候,大多數(shù)會(huì)出現(xiàn)歷史搜索,也就是搜索記錄,我們首先需要的就是進(jìn)行歷史搜索的渲染,我這里歷史搜索都是用localStorage進(jìn)行存儲(chǔ),大家根據(jù)需要可以進(jìn)行對(duì)應(yīng)的存儲(chǔ)或者獲取。
var history_search = [];//存儲(chǔ)歷史搜索數(shù)據(jù) //獲取歷史搜索數(shù)據(jù),若沒(méi)有則為空 if(localStorage.getItem("history_search")){ history_search = JSON.parse(localStorage.getItem("history_search"));//獲取歷史搜索數(shù)據(jù) }else{ history_search = []; }
????接下來(lái)在獲取了歷史記錄的前提下,我們要把歷史記錄渲染到頁(yè)面上
//渲染歷史記錄 function setpage(){ var product_list = ""; //動(dòng)態(tài)添加元素至頁(yè)面上 if(history_search.length != 0){ $(".search_history").show(); if(history_search.length >= 10){ for(var i = 0; i < 10 ;i++){ product_list = ""+history_search[i]+""; $(".search_find_line").append(product_list); } }else{ for(var i = 0; i < history_search.length;i++){ product_list = ""+history_search[i]+""; $(".search_find_line").append(product_list); } } }else{ $(".search_history").hide(); } } setpage();
????這里我們需要注意的是,一般的歷史記錄不會(huì)是太多的,一般會(huì)顯示前十條最近搜索的,我這邊在渲染的時(shí)候做了截取,其實(shí)在存的時(shí)候就應(yīng)該去做判斷,在超出10條或者規(guī)定條數(shù)的時(shí)候我們只保存十條或者規(guī)定條數(shù),然后在渲染的時(shí)候就不需要再去截取了。
????接下來(lái)需要做的處理就是在輸入關(guān)鍵字的時(shí)候,一些請(qǐng)求和緩存搜索出來(lái)的提示數(shù)據(jù)
var obj_arr = [];//請(qǐng)求結(jié)果 var timeout = 0; var keyName = "";//搜索關(guān)鍵字 var ajaxCache = {};//定義緩存對(duì)象(保存請(qǐng)求出來(lái)的數(shù)據(jù))
????這里我先把另外兩個(gè)方法先提出來(lái)先寫了,一個(gè)是渲染頁(yè)面的方法,一個(gè)是判斷字符串是否為空的方法,這兩個(gè)方法在接下來(lái)的邏輯中需要調(diào)用。
//渲染頁(yè)面方法 function setListPage(obj,no){ console.log(obj); console.log(no); ajaxCache = {}; obj_arr = obj; $(".search_find_line").empty(); if(no == 1){ $(".search_history").hide(); }else{ $(".search_history").show(); } var search_res = ""; for(var i = 0; i < obj.length;i++){ search_res = ""+obj[i]+""; $(".search_find_line").append(search_res); } } //判斷字符串是不是為空 function isNull( str ){ if ( str == "" ) return true; var regu = "^[ ]+$"; var re = new RegExp(regu); return re.test(str); }
????這里就是最重要的一部分了。
//當(dāng)按鈕被松開時(shí),觸發(fā)事件 $(".searchProduct").keyup(function(evt){ //獲取到關(guān)鍵字 keyName = $(this).val(); //判斷關(guān)鍵字是否為空 if(isNull(keyName) == false || keyName != ""){ //若輸入字符串不為空,則顯示網(wǎng)絡(luò)請(qǐng)求搜索。 clearTimeout(timeout); timeout = setTimeout(function(){ if(!!ajaxCache[keyName]){ //顯示自動(dòng)提示框,給框里填關(guān)聯(lián)詞條的內(nèi)容 setListPage(ajaxCache[keyName],1); ajaxCache = {}; }else{ var sendData = { "keyName":keyName }; $.ajax({ type: "POST", url: url,//我們自個(gè)的接口沒(méi)法公開,大家可以用自己的。 data:JSON.stringify(sendData), dataType: "json", success: function (data) { console.log(data); if(data){ if(data.data){ //顯示自動(dòng)提示框,給框里填關(guān)聯(lián)詞條的內(nèi)容 ajaxCache[keyName]=[]; ajaxCache[keyName]=data.data;//給緩存對(duì)象賦值 setListPage(data.data,1); } } }, error: function (err) { console.log(err); } }); } },200); }else{ //若輸入字符串為空,則顯示歷史搜索。 ajaxCache = {}; if(history_search.length == 0){ //若數(shù)組為空,歷史搜索不顯示 $(".search_history").hide(); }else{ $(".search_history").show(); setListPage(history_search,2) } } //手機(jī)端按下右下角的搜索按鈕的時(shí)候觸發(fā)事件 if (evt.keyCode == 13) { localStorage.setItem("search_keyName",keyName); var count = 0; //判斷歷史搜索中是否已經(jīng)存在當(dāng)前搜索的關(guān)鍵字 for(var j = 0; j < history_search.length;j++){ if(keyName == history_search[j]){ count += 1; }else{ count += 0; } } //如果沒(méi)有,則添加進(jìn)歷史搜索 if(count == 0){ history_search.unshift(keyName); } //這邊缺少的處理是歷史搜索排序的問(wèn)題。 localStorage.setItem("history_search",JSON.stringify(history_search)); window.location.href="";//跳轉(zhuǎn)到搜索結(jié)果頁(yè)之類的頁(yè)面 }
????這就基本完成了,這里沒(méi)有加一個(gè)搜索結(jié)果頁(yè),在出現(xiàn)提示搜索的時(shí)候,應(yīng)該在上添加點(diǎn)擊事件,以跳轉(zhuǎn)到搜索結(jié)果頁(yè)之類的,這邊可以根據(jù)自己的需求來(lái)處理。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/100626.html
摘要:當(dāng)按鈕被松開時(shí),觸發(fā)事件獲取到關(guān)鍵字判斷關(guān)鍵字是否為空若輸入字符串不為空則顯示網(wǎng)絡(luò)請(qǐng)求搜索。顯示自動(dòng)提示框,給框里填關(guān)聯(lián)詞條的內(nèi)容給緩存對(duì)象賦值若輸入字符串為空則顯示歷史搜索。 ????最近項(xiàng)目一直在迭代更新,沒(méi)有什么新的東西做,所以拿出來(lái)一個(gè)搜索的小模塊分享下,功能就是輸入關(guān)鍵字能出來(lái)相關(guān)字的聯(lián)想吧,刪除一些字的時(shí)候順帶可以保存上一段的聯(lián)想,從外觀上來(lái)看,效果還罷了,這里分享給大家,...
摘要:當(dāng)按鈕被松開時(shí),觸發(fā)事件獲取到關(guān)鍵字判斷關(guān)鍵字是否為空若輸入字符串不為空則顯示網(wǎng)絡(luò)請(qǐng)求搜索。顯示自動(dòng)提示框,給框里填關(guān)聯(lián)詞條的內(nèi)容給緩存對(duì)象賦值若輸入字符串為空則顯示歷史搜索。 ????最近項(xiàng)目一直在迭代更新,沒(méi)有什么新的東西做,所以拿出來(lái)一個(gè)搜索的小模塊分享下,功能就是輸入關(guān)鍵字能出來(lái)相關(guān)字的聯(lián)想吧,刪除一些字的時(shí)候順帶可以保存上一段的聯(lián)想,從外觀上來(lái)看,效果還罷了,這里分享給大家,...
摘要:寫在前面沒(méi)錯(cuò),這就是慕課網(wǎng)上的那個(gè)音樂(lè)播放器,后臺(tái)是某音樂(lè)播放器的線上接口扒取,雖然這類項(xiàng)目寫的人很多,但不得不說(shuō)這還是個(gè)少有的適合提升的好項(xiàng)目,做這個(gè)項(xiàng)目除了想寫一個(gè)比較大并且功能復(fù)雜的項(xiàng)目,主要原因是要拿它來(lái)應(yīng)對(duì)面試,也確實(shí)對(duì)我的業(yè)務(wù)能 寫在前面 沒(méi)錯(cuò),這就是慕課網(wǎng)上的那個(gè)vue音樂(lè)播放器,后臺(tái)是某音樂(lè)播放器的線上接口扒取,雖然這類項(xiàng)目寫的人很多,但不得不說(shuō)這還是個(gè)少有的適合vu...
閱讀 3158·2021-11-22 13:54
閱讀 3449·2021-11-15 11:37
閱讀 3612·2021-10-14 09:43
閱讀 3507·2021-09-09 11:52
閱讀 3612·2019-08-30 15:53
閱讀 2474·2019-08-30 13:50
閱讀 2065·2019-08-30 11:07
閱讀 897·2019-08-29 16:32