欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

微信小程序?qū)崿F(xiàn)搜索關(guān)鍵詞高亮的示例代碼

 更新時間:2021年03月30日 09:32:50   作者:鵬多多  
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)搜索關(guān)鍵詞高亮的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

1,前言

項目中碰到一個需求,搜索數(shù)據(jù)并且關(guān)鍵詞要高亮顯示,接到需求,馬上開干。先上效果圖。源碼已經(jīng)做成了小程序代碼片段,放入了GitHub了,文章底部有源碼鏈接。

2,思路

博主第一時間想到的就是使用split,根據(jù)搜索的關(guān)鍵詞,處理后臺返回的數(shù)據(jù),然后indexOf找到關(guān)鍵字,給每個字添加deep字段,deep為true,則高亮,為false,則正常。由于是小程序,所以樓主直接做成了一個高亮組件,代碼很簡單,實現(xiàn)步驟如下。

3,代碼邏輯

模擬數(shù)據(jù)如下

list:[
 '武漢大學(xué)',
 '華中科技大學(xué)',
 '華中師范大學(xué)',
 '中南財經(jīng)政法大學(xué)',
 '中國地質(zhì)大學(xué)',
 '武漢理工大學(xué)',
 '華中農(nóng)業(yè)大學(xué)',
 '武漢科技大學(xué)',
],

在data中定義了一個空數(shù)組,用于存放根據(jù)搜索key過濾后的數(shù)據(jù)

filterList:[],//過濾后的

搜索的wxml和方法

// wxml
<view class="search_box">
 <input type="text" placeholder="請輸入武漢的985/211大學(xué)" bindinput="searchValue" class="search"/>
</view>

// 搜索方法
searchValue(e){
 let val = e.detail.value;
 this.setData({ value:val })
 if(val.length > 0){
  this.setData({ filterList:[] })
  let arr = [];
  for(let i = 0;i < this.data.list.length;i++){
   if(this.data.list[i].indexOf(val) > -1){
    arr.push(this.data.list[i])
   }
  }
  this.setData({ filterList: arr })
 }else{
  this.setData({ filterList: [] })
 }
}

定義了一個高亮組件highlight

"usingComponents": {
  "highlight":"../../components/highlight/highlight"
 }

在頁面中將搜索出來的每一項item和key參數(shù)傳遞給組件

<view class="list_li" wx:for="{{ filterList }}" wx:key="index" data-index="{{ index }}" bindtap="pitchOn">
 <highlight text="{{ item }}" key="{{ value }}" />
</view>

在組件中接收

properties: {
 text:String,
 key:{
  type:String,
  value:'',
  observer:'_changeText'
 }
}

組件的初始數(shù)據(jù)

data: {
 highlightList:[],//處理后的數(shù)據(jù)
}

組件的wxml

<text class="{{ item.deep ? 'green' : '' }}" wx:for="{{ highlightList }}" wx:key="index">{{ item.val }}</text>

組件的高亮數(shù)據(jù)處理

// 非空過濾
 _changeText(e){
  if(e.length > 0 && this.properties.text.indexOf(e) > -1){
   this._filterHighlight(this.properties.text, e);
  }
 },
 /**
 * 關(guān)鍵字高亮處理
 * @param { String } text - 文本
 * @param { String } key - 關(guān)鍵字
 */
 _filterHighlight(text, key){
  let textList = text.split("");
  let keyList = key.split("");
  let list = [];
  for(let i = 0;i < textList.length;i++){
   let obj = {
    deep:false,
    val:textList[i]
   }
   list.push(obj);
  };
  for(let k = 0;k < keyList.length;k++){
   list.forEach(item => {
    if(item.val === keyList[k]){
     item.deep = true;
    }
   })
  }
  this.setData({ highlightList:list })
 }

源碼GitHub地址:https://github.com/pdd11997110103/ComponentWarehouse

到此這篇關(guān)于微信小程序?qū)崿F(xiàn)搜索關(guān)鍵詞高亮的示例代碼的文章就介紹到這了,更多相關(guān)小程序搜索關(guān)鍵詞高亮內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 微信小程序自定義Dialog彈框

    微信小程序自定義Dialog彈框

    這篇文章主要為大家詳細(xì)介紹了微信小程序自定義Dialog彈框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • TypeScript?使用?Tuple?Union?聲明函數(shù)重載

    TypeScript?使用?Tuple?Union?聲明函數(shù)重載

    這篇文章主要介紹了TypeScript?使用?Tuple?Union?聲明函數(shù)重載,TypeScript 中為函數(shù)添加多個簽名后,依然需要添加相應(yīng)的代碼來判斷并從不同的簽名參數(shù)列表中獲取對應(yīng)的參數(shù),下文就來探索方法和技巧吧
    2022-04-04
  • 你應(yīng)該了解的JavaScript Array.map()五種用途小結(jié)

    你應(yīng)該了解的JavaScript Array.map()五種用途小結(jié)

    大家都知道m(xù)ap() 方法返回一個新數(shù)組,數(shù)組中的元素為原始數(shù)組元素調(diào)用函數(shù)處理后的值。下面這篇文章主要給大家介紹了關(guān)于JavaScript Array.map()的五種用途,需要的朋友可以參考下
    2018-11-11
  • js 獲取經(jīng)緯度的實現(xiàn)方法

    js 獲取經(jīng)緯度的實現(xiàn)方法

    下面小編就為大家?guī)硪黄猨s 獲取經(jīng)緯度的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-06-06
  • 基于JS實現(xiàn)文字轉(zhuǎn)語音即文本朗讀

    基于JS實現(xiàn)文字轉(zhuǎn)語音即文本朗讀

    這篇文章主要為大家詳細(xì)介紹了JavaScript如何利用SpeechSynthesis實現(xiàn)文字轉(zhuǎn)語音即文本朗讀的功能,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-10-10
  • 原生js實現(xiàn)商品放大鏡效果

    原生js實現(xiàn)商品放大鏡效果

    本文主要分享了原生js實現(xiàn)商品放大鏡效果的示例代碼。具有一定的參考價值,下面跟著小編一起來看下吧
    2017-01-01
  • 微信小程序?qū)崿F(xiàn)點擊出現(xiàn)彈窗

    微信小程序?qū)崿F(xiàn)點擊出現(xiàn)彈窗

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)點擊出現(xiàn)彈窗,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • js日期相關(guān)函數(shù)dateAdd,dateDiff,dateFormat等介紹

    js日期相關(guān)函數(shù)dateAdd,dateDiff,dateFormat等介紹

    這篇文章主要介紹了js日期相關(guān)函數(shù)dateAdd,dateDiff,dateFormat等介紹,需要的朋友可以參考下
    2016-09-09
  • javascript精確統(tǒng)計網(wǎng)站訪問量實例代碼

    javascript精確統(tǒng)計網(wǎng)站訪問量實例代碼

    網(wǎng)站一般都有訪問量統(tǒng)計工具,比較高效實用的工具多種多樣,這篇文章主要介紹了javascript精確統(tǒng)計網(wǎng)站訪問量實例代碼,感興趣的小伙伴們可以參考一下
    2015-12-12
  • uniapp-路由uni-simple-router安裝配置教程

    uniapp-路由uni-simple-router安裝配置教程

    專為uniapp打造的路由器,和uniapp深度集成,uniapp用到了很多vue的api,但在路由管理的功能相對于vue-router還是比較欠缺的,比如全局導(dǎo)航守衛(wèi),本文給大家講解uniapp-路由uni-simple-router相關(guān)知識,感興趣的朋友跟隨小編一起看看吧
    2022-11-11

最新評論