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之間的關系,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10Vue.js中extend選項和delimiters選項的比較
這篇文章主要介紹了Vue.js中extend選項和delimiters選項的比較的相關資料,需要的朋友可以參考下2017-07-07