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

Vue實(shí)現(xiàn)多個關(guān)鍵詞高亮顯示功能

 更新時間:2024年12月27日 09:26:03   作者:婷婷婷婷  
在現(xiàn)代網(wǎng)頁開發(fā)中,常常需要實(shí)現(xiàn)高亮顯示關(guān)鍵詞的功能,這篇文章將探討如何通過?Vue.js?中的?highlightText來實(shí)現(xiàn)這一功能,感興趣的可以了解下

在現(xiàn)代網(wǎng)頁開發(fā)中,常常需要實(shí)現(xiàn)高亮顯示關(guān)鍵詞的功能。例如,在一個搜索結(jié)果頁面,用戶可能輸入某個關(guān)鍵詞,并希望看到該關(guān)鍵詞在相關(guān)內(nèi)容中的高亮顯示。下面我們將探討如何通過 JavaScript 來實(shí)現(xiàn)這一功能,具體以 Vue.js 中的 highlightText 方法為例。

1. 理解 escapeRegExp 方法

escapeRegExp 是一個將特殊字符轉(zhuǎn)義為正則表達(dá)式安全字符的函數(shù)。正則表達(dá)式中有許多特殊字符,例如 .、*、+ 等,這些字符在正則中有特定的含義。如果我們希望這些字符作為普通字符進(jìn)行匹配,就需要對它們進(jìn)行轉(zhuǎn)義。

escapeRegExp(str) {
    return str.replace(/([.*+?^=!:${}()|[]/\])/g, '\$1');
}

此方法使用了正則表達(dá)式,將輸入字符串中的特殊字符(如 *、+、? 等)替換為它們的轉(zhuǎn)義字符(如 *、+、?)。這確保了我們可以在正則表達(dá)式中安全地使用用戶輸入的任何字符串,無論其是否包含特殊字符。

2. 高亮顯示文本的核心方法

highlightText 方法的核心作用是根據(jù)用戶輸入的關(guān)鍵詞在文本中查找并高亮顯示匹配項(xiàng)。它使用了前面提到的 escapeRegExp 方法來確保每個關(guān)鍵詞都被正確轉(zhuǎn)義,然后利用正則表達(dá)式實(shí)現(xiàn)高亮功能。

highlightText(fieldValue) {
    const keyword = this.queryParams.keyword || '';
    if (!keyword) return fieldValue;

    const keywords = keyword.split('');
    if (keywords.length === 0 || !fieldValue) return fieldValue;

    const regexString = keywords.map(keyword => `(${this.escapeRegExp(keyword)})`).join('|');
    const regex = new RegExp(regexString, 'gi');

    return fieldValue.replace(regex, (match) => {
        return `<span class="highlight">${match}</span>`;
    });
}

代碼解析:

獲取關(guān)鍵詞:首先從 queryParams 中獲取用戶輸入的關(guān)鍵詞(this.queryParams.keyword)。如果沒有輸入關(guān)鍵詞,則直接返回原始文本。

拆分關(guān)鍵詞:將輸入的關(guān)鍵詞按字符拆分成數(shù)組。如果拆分后的數(shù)組為空或 fieldValue 本身為空,直接返回原始文本。

生成正則表達(dá)式:使用 map 方法將每個字符轉(zhuǎn)義,并將所有轉(zhuǎn)義后的字符拼接成一個大的正則表達(dá)式字符串。這里使用了 | 來分隔每個字符,表示“或”操作,即如果文本中出現(xiàn)任何一個關(guān)鍵詞字符,都會被匹配。

正則替換:通過 replace 方法,使用 span 標(biāo)簽包裹所有匹配的字符,以實(shí)現(xiàn)高亮顯示。'gi' 標(biāo)志表示全局匹配且不區(qū)分大小寫。

返回高亮后的文本:將高亮后的文本作為 HTML 返回,可以直接插入到頁面中。

3. 如何使用 highlightText

假設(shè)我們有一個 Vue.js 組件,它展示了一段文本,并希望在文本中高亮顯示用戶輸入的關(guān)鍵詞??梢赃@樣調(diào)用 highlightText 方法:

<template>
  <div v-html="highlightText('這是一個測試文本,測試關(guān)鍵字高亮顯示')"></div>
</template>

<script>
export default {
  data() {
    return {
      queryParams: {
        keyword: '測試'
      }
    };
  },
  methods: {
    escapeRegExp(str) {
      return str.replace(/([.*+?^=!:${}()|[]/\])/g, '\$1');
    },
    highlightText(fieldValue) {
      const keyword = this.queryParams.keyword || '';
      if (!keyword) return fieldValue;
      const keywords = keyword.split('');
      if (keywords.length === 0 || !fieldValue) return fieldValue;
      const regexString = keywords.map(keyword => `(${this.escapeRegExp(keyword)})`).join('|');
      const regex = new RegExp(regexString, 'gi');
      return fieldValue.replace(regex, (match) => {
        return `<span class="highlight">${match}</span>`;
      });
    }
  }
};
</script>

<style scoped>
.highlight {
  background-color: yellow;
}
</style>

在這個示例中,我們通過 v-html 指令將高亮后的文本渲染到頁面中,并通過 CSS 設(shè)置高亮的背景顏色。用戶輸入的關(guān)鍵詞 測試 會在文本中被高亮顯示。

4. 總結(jié)

通過以上的方法,我們能夠方便地實(shí)現(xiàn)一個高亮顯示關(guān)鍵詞的功能,無論是用于搜索結(jié)果展示,還是其他需要文本高亮的場景。這種方式不僅支持簡單的字符高亮,還能正確處理用戶輸入的特殊字符,保證功能的魯棒性和安全性。

到此這篇關(guān)于Vue實(shí)現(xiàn)多個關(guān)鍵詞高亮顯示功能的文章就介紹到這了,更多相關(guān)Vue關(guān)鍵詞高亮內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue中使用better-scroll實(shí)現(xiàn)滑動效果及注意事項(xiàng)

    vue中使用better-scroll實(shí)現(xiàn)滑動效果及注意事項(xiàng)

    這篇文章主要介紹了vue中使用better-scroll實(shí)現(xiàn)滑動效果,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-11-11
  • vue限制文本輸入框只允許輸入字母、數(shù)字、禁止輸入特殊字符

    vue限制文本輸入框只允許輸入字母、數(shù)字、禁止輸入特殊字符

    這篇文章主要介紹了vue限制文本輸入框只允許輸入字母、數(shù)字、不允許輸入特殊字符,通過監(jiān)聽表單輸入的內(nèi)容,使用方法的缺陷,本文通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友參考下吧
    2023-10-10
  • Vue性能優(yōu)化的方法

    Vue性能優(yōu)化的方法

    這篇文章主要介紹了Vue性能優(yōu)化的方法,文中講解非常細(xì)致,幫助大家更好的理解和學(xué)習(xí)vue,感興趣的朋友可以了解下
    2020-07-07
  • vue2從template到render模板編譯入口詳解

    vue2從template到render模板編譯入口詳解

    這篇文章主要為大家介紹了vue2從template到render模板編譯入口詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • vue常用高階函數(shù)及綜合實(shí)例

    vue常用高階函數(shù)及綜合實(shí)例

    這篇文章主要介紹了vue常用高階函數(shù)及綜合案例,文章內(nèi)容講解的很清晰,有對于這方面感興趣的同學(xué)可以研究下
    2021-02-02
  • 利用vuex-persistedstate將vuex本地存儲實(shí)現(xiàn)

    利用vuex-persistedstate將vuex本地存儲實(shí)現(xiàn)

    這篇文章主要介紹了利用vuex-persistedstate將vuex本地存儲的實(shí)現(xiàn),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue 3 中 h 方法示例詳解

    Vue 3 中 h 方法示例詳解

    Vue3中的h方法用于創(chuàng)建虛擬DOM節(jié)點(diǎn),是渲染函數(shù)的核心,它接受三個參數(shù):type(節(jié)點(diǎn)類型)、props(屬性對象)和children(子節(jié)點(diǎn)),通過示例展示了如何使用h方法創(chuàng)建簡單的HTML元素、帶有屬性的元素、嵌套元素和自定義組件,感興趣的朋友一起看看吧
    2025-03-03
  • 詳解element-ui表格中勾選checkbox,高亮當(dāng)前行

    詳解element-ui表格中勾選checkbox,高亮當(dāng)前行

    這篇文章主要介紹了詳解element-ui表格中勾選checkbox,高亮當(dāng)前行,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • Vue實(shí)現(xiàn)dom元素拖拽并限制移動范圍的操作代碼

    Vue實(shí)現(xiàn)dom元素拖拽并限制移動范圍的操作代碼

    這篇文章主要介紹了Vue實(shí)現(xiàn)dom元素拖拽并限制移動范圍的操作代碼,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-12-12
  • element-ui中Table表格省市區(qū)合并單元格的方法實(shí)現(xiàn)

    element-ui中Table表格省市區(qū)合并單元格的方法實(shí)現(xiàn)

    這篇文章主要介紹了element-ui中Table表格省市區(qū)合并單元格的方法實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08

最新評論