Vue如何比較字符串變化并高亮變化的部分
最近有個(gè)需求為只展示一個(gè)字段變更前和變更后變化的部分,新增為紅色,刪除的灰色加上刪除線(xiàn)展示
最終效果如下:

其實(shí)本質(zhì)上就是兩個(gè)文本的diff,找到新增的和刪除的然后加上樣式,這里用的庫(kù)為diff_match_patch
1.install
npm i diff_match_patch -S
2.初始化
這個(gè)庫(kù)提供了一個(gè)構(gòu)造函數(shù)diff_match_patch,返回一個(gè)diff實(shí)例供我們使用他的api,官方有很多方法
這里需求只用到了它的字符串對(duì)比:

diff_main方法提供了兩個(gè)入?yún)樾枰獙?duì)比的字符串,返回一個(gè)二維數(shù)組,數(shù)組的第一項(xiàng)為內(nèi)容類(lèi)型,0為公共的也就是沒(méi)有變化的部分,1為新增,2為刪除的,因此,我們可以對(duì)其進(jìn)行封裝
3.封裝
在utils文件夾下建立一個(gè)diff.js工具類(lèi).用來(lái)封裝:
// 因?yàn)閷?dǎo)出的構(gòu)造函數(shù)為下劃線(xiàn)命名,這里改為駝峰
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é)果 為一個(gè)二維數(shù)組
*/
diffText(prevText, currentText) {
const diffResults = diffMatchPatch.diff_main(prevText, currentText);
return diffResults;
},
}
}
// 初始化后導(dǎo)出
export default createDiffMatchPatch();使用時(shí)直接導(dǎo)入:
import diff from "@/utils/diff";
const diffResults = diff.diffText(
record.prevDetail,
record.currentDetail
);將比較好的diffResults這個(gè)二維數(shù)組進(jìn)行解析拼接成富文本:
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é)果 為一個(gè)二維數(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("");
};提前定義好高亮的樣式,然后進(jìn)行拼接即可
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue?serve及其與vue-cli-service?serve之間的關(guān)系解讀
這篇文章主要介紹了vue?serve及其與vue-cli-service?serve之間的關(guān)系,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10
Vue如何循環(huán)提取對(duì)象數(shù)組中的值
這篇文章主要介紹了Vue如何循環(huán)提取對(duì)象數(shù)組中的值,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11
webpack4打包vue前端多頁(yè)面項(xiàng)目
這篇文章主要介紹了webpack4打包vue前端多頁(yè)面項(xiàng)目的相關(guān)知識(shí),非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-09-09
vscode 開(kāi)發(fā)Vue項(xiàng)目的方法步驟
這篇文章主要介紹了vscode 開(kāi)發(fā)Vue項(xiàng)目的方法步驟,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-11-11
Vuejs實(shí)現(xiàn)購(gòu)物車(chē)功能
這篇文章主要為大家詳細(xì)介紹了Vuejs實(shí)現(xiàn)購(gòu)物車(chē)功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-11-11
Vue.js中extend選項(xiàng)和delimiters選項(xiàng)的比較
這篇文章主要介紹了Vue.js中extend選項(xiàng)和delimiters選項(xiàng)的比較的相關(guān)資料,需要的朋友可以參考下2017-07-07

