亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue如何比較字符串變化并高亮變化的部分

 更新時間:2023年12月29日 08:40:22   作者:williamyi74  
這篇文章主要介紹了Vue如何比較字符串變化并高亮變化的部分問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

最近有個需求為只展示一個字段變更前和變更后變化的部分,新增為紅色,刪除的灰色加上刪除線展示

最終效果如下:

其實本質(zhì)上就是兩個文本的diff,找到新增的和刪除的然后加上樣式,這里用的庫為diff_match_patch

1.install

npm i diff_match_patch -S

2.初始化

這個庫提供了一個構(gòu)造函數(shù)diff_match_patch,返回一個diff實例供我們使用他的api,官方有很多方法

這里需求只用到了它的字符串對比:

diff_main方法提供了兩個入?yún)樾枰獙Ρ鹊淖址?,返回一個二維數(shù)組,數(shù)組的第一項為內(nèi)容類型,0為公共的也就是沒有變化的部分,1為新增,2為刪除的,因此,我們可以對其進行封裝

3.封裝

在utils文件夾下建立一個diff.js工具類.用來封裝:

// 因為導出的構(gòu)造函數(shù)為下劃線命名,這里改為駝峰
import { diff_match_patch as DiffMatchPatch } from 'diff_match_patch';
 
const createDiffMatchPatch = () => {
    const diffMatchPatch = new DiffMatchPatch();
    const DIFF_IDENTIFIER = {
        INSERTION: 1, // 新增的
        DELETION: -1, // 刪除的
        EQUALITY: 0, // 公共的
    }
    return {
        DIFF_IDENTIFIER,
        /**
         * diff字符串的變更
         * @param {String} prevText 上一次的內(nèi)容
         * @param {String} currentText 這次要diff的內(nèi)容
         * @return {{Array.<Array.<number|string>>}} diff后的結(jié)果 為一個二維數(shù)組
         */
        diffText(prevText, currentText) {
            const diffResults = diffMatchPatch.diff_main(prevText, currentText);
            return diffResults;
        },
    }
}
// 初始化后導出
export default createDiffMatchPatch();

使用時直接導入:

import diff from "@/utils/diff";
            const diffResults = diff.diffText(
              record.prevDetail,
              record.currentDetail
            );

將比較好的diffResults這個二維數(shù)組進行解析拼接成富文本:

import { CHANGE_EVENT_TYPE } from "@/constant/services/detail";
import { DOG_TEXT, DOG_TYPE } from '@/constant/services/detail';
import diff from "@/utils/diff";
 
/**
 * 高亮變更的內(nèi)容
 * @param {{Array.<Array.<number|string>>}} diffResults diff后的結(jié)果 為一個二維數(shù)組
 * @return {String} 返回高亮的富文本片段
 */
const useHighlightCurrentDetail = (diffResults) => {
    const richTextFragments = [];
    const { DIFF_IDENTIFIER } = diff;
    for (let i = 0; i < diffResults.length; i++) {
        const [identifier, text] = diffResults[i];
        switch (identifier) {
            case DIFF_IDENTIFIER.INSERTION:
                richTextFragments.push(`<em class="highlight-insertion">${text}</em>`);
                break;
            case DIFF_IDENTIFIER.DELETION:
                richTextFragments.push(`<del class="highlight-deletion">${text}</del>`);
                break;
            case DIFF_IDENTIFIER.EQUALITY:
                richTextFragments.push(text);
                break;
            default:
                break;
        }
    }
    return richTextFragments.join("");
};

提前定義好高亮的樣式,然后進行拼接即可

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • vue?serve及其與vue-cli-service?serve之間的關系解讀

    vue?serve及其與vue-cli-service?serve之間的關系解讀

    這篇文章主要介紹了vue?serve及其與vue-cli-service?serve之間的關系,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Vue+canvas實現(xiàn)視頻截圖功能

    Vue+canvas實現(xiàn)視頻截圖功能

    這篇文章主要為大家詳細介紹了Vue+canvas實現(xiàn)視頻截圖功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • Vue如何循環(huán)提取對象數(shù)組中的值

    Vue如何循環(huán)提取對象數(shù)組中的值

    這篇文章主要介紹了Vue如何循環(huán)提取對象數(shù)組中的值,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-11-11
  • vue視圖不更新情況詳解

    vue視圖不更新情況詳解

    這篇文章主要介紹了vue視圖不更新情況詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-05-05
  • webpack4打包vue前端多頁面項目

    webpack4打包vue前端多頁面項目

    這篇文章主要介紹了webpack4打包vue前端多頁面項目的相關知識,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-09-09
  • vscode 開發(fā)Vue項目的方法步驟

    vscode 開發(fā)Vue項目的方法步驟

    這篇文章主要介紹了vscode 開發(fā)Vue項目的方法步驟,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • vue axios用法教程詳解

    vue axios用法教程詳解

    axios是vue-resource后出現(xiàn)的Vue請求數(shù)據(jù)的插件。下面我們通過本文給大家介紹vue axios用法教程詳解,感興趣的朋友一起看看吧
    2017-07-07
  • Vuejs實現(xiàn)購物車功能

    Vuejs實現(xiàn)購物車功能

    這篇文章主要為大家詳細介紹了Vuejs實現(xiàn)購物車功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • Vue.js中extend選項和delimiters選項的比較

    Vue.js中extend選項和delimiters選項的比較

    這篇文章主要介紹了Vue.js中extend選項和delimiters選項的比較的相關資料,需要的朋友可以參考下
    2017-07-07
  • Vue虛擬dom被創(chuàng)建的方法

    Vue虛擬dom被創(chuàng)建的方法

    這篇文章主要介紹了Vue虛擬dom是如何被創(chuàng)建的方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-10-10

最新評論