前端JavaScript實(shí)現(xiàn)本地模糊搜索功能的方法實(shí)例
一、項(xiàng)目前景
隨著vue、react在實(shí)際開(kāi)發(fā)中應(yīng)運(yùn)越來(lái)越廣泛,前端對(duì)數(shù)據(jù)的處理越來(lái)越多。這篇文章主要目的就是為了對(duì)服務(wù)端返回的數(shù)據(jù)進(jìn)行處理,按照條件進(jìn)行模糊查詢,從而減少向服務(wù)端發(fā)送請(qǐng)求的次數(shù),來(lái)提高性能和用戶體驗(yàn)。下面以一個(gè)簡(jiǎn)單的DEMO,來(lái)實(shí)現(xiàn)模糊查詢的功能:
測(cè)試用的數(shù)據(jù)如下:
var data = [{
"title": "你的失戀修復(fù)期有多長(zhǎng)?",
"title_image": "https://img.doutuimao.net/dtmimg/b7c9ec393414982682e5a477eb995b55",
"desc": "美食餐飲測(cè)試一下你的失戀修復(fù)期有多長(zhǎng)",
"id": "2",
"num": 951357,
"flag": "01"
},
{
"title": "你的撒嬌指數(shù)有多高?",
"title_image": "https://img.doutuimao.net/dtmimg/60d8ed86d1f72357c194506270c72ac1",
"desc": "美食餐飲會(huì)撒嬌的女人最好命,你有多會(huì)撒嬌?你撒起嬌來(lái)魅力又是怎么樣的?快來(lái)測(cè)測(cè)吧!",
"id": "3",
"num": 963258,
"flag": "01"
},
{
"title": "你未來(lái)的結(jié)婚方式?",
"title_image": "https://img.doutuimao.net/dtmimg/538632e75159ce8e586778d289c66a11",
"desc": "相信很多人都對(duì)自己未來(lái)的結(jié)婚方式充滿期待,想知道你未來(lái)的結(jié)婚方式嗎?",
"id": "4",
"num": 879564,
"flag": "01"
},
]
二、涉及知識(shí)點(diǎn)
Object.assign()的用法
Object.assign方法用來(lái)將源對(duì)象(source)的所有可枚舉屬性,復(fù)制到目標(biāo)對(duì)象(target)。它至少需要兩個(gè)對(duì)象作為參數(shù),第一個(gè)參數(shù)是目標(biāo)對(duì)象,后面的參數(shù)都是源對(duì)象。
// 處理原始數(shù)組
let arrnew = data.map((item, index) => {
return Object.assign({}, {
'desc': item.desc,
})
})
filter()方法
filter()方法用于過(guò)濾數(shù)組元素。該方法創(chuàng)建一個(gè)新數(shù)組, 其中包含通過(guò)所提供函數(shù)實(shí)現(xiàn)的測(cè)試的所有元素。filter()不會(huì)對(duì)空數(shù)組進(jìn)行檢測(cè),也不會(huì)改變?cè)紨?shù)組。
indexOf()模糊查詢
indexOf() 方法可返回某個(gè)指定的字符串值在字符串中首次出現(xiàn)的位置。如果要檢索的字符串值沒(méi)有出現(xiàn),則該方法返回 -1。與filter()方法配合,可以檢測(cè)數(shù)組中是否包含輸入的值,并返回。
var newData = arrnew.filter(item => {
if (item.desc.indexOf(value) > -1) { //indexOf方法中如果xxx.indexOf("")返回值為0
return item
}
return newData
})
DEMO完整代碼如下:
<div class="wrap">
<input type="text" id="demo">
<ul id="newsBox">
</ul>
</div>
function creat() {
var value = input.value;
var html = "";
let arrnew = data.map((item, index) => {
return Object.assign({}, {
'desc': item.desc,
})
})
var newData = arrnew.filter(item => {
if (item.desc.indexOf(value) > -1) { //indexOf方法中如果xxx.indexOf("")返回值為0
return item
}
return newData
})
if (newData.length > 0) {
for (var i = 0; i < newData.length; i++) {
html += `<li>${newData[i].desc}</li>`
}
} else {
html += `<li>暫無(wú)數(shù)據(jù)</li>`
}
ul.innerHTML = html;
}
creat()
input.onchange = function(e) {
creat()
}
總結(jié)
到此這篇關(guān)于JavaScript實(shí)現(xiàn)本地模糊搜索功能的文章就介紹到這了,更多相關(guān)JS本地模糊搜索內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
分享9個(gè)最好用的JavaScript開(kāi)發(fā)工具和代碼編輯器
這篇文章主要介紹了9個(gè)最好用的JavaScript開(kāi)發(fā)工具和代碼編輯器,需要的朋友可以參考下2015-03-03
小程序?qū)崿F(xiàn)人臉識(shí)別的項(xiàng)目實(shí)踐
人臉識(shí)別在現(xiàn)在很多地方都可以用的到,例如支付,解鎖等,本文就來(lái)介紹一下小程序?qū)崿F(xiàn)人臉識(shí)別,具有一定的參考價(jià)值,感興趣的可以了解一下2023-10-10
js判斷iframe中元素是否存在的實(shí)現(xiàn)代碼
這篇文章主要介紹了js判斷iframe中元素是否存在的實(shí)現(xiàn)代碼,需要的朋友可以參考下2016-12-12
JavaScript中最常見(jiàn)的三個(gè)面試題解析
JavaScript是所有現(xiàn)代瀏覽器的官方語(yǔ)言。 因此,JavaScript 問(wèn)題出現(xiàn)在各種開(kāi)發(fā)人員的面試中。這篇文章主要跟大家分享了關(guān)于JavaScript中最常見(jiàn)的三個(gè)面試題,需要的朋友可以參考學(xué)習(xí),下面來(lái)一起看看吧。2017-03-03
微信小程序結(jié)合mock.js實(shí)現(xiàn)后臺(tái)模擬及調(diào)試
這篇文章主要介紹了微信小程序結(jié)合mock.js實(shí)現(xiàn)后臺(tái)模擬及調(diào)試,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03

