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

JS實現(xiàn)文本比較差異的示例代碼

 更新時間:2023年12月12日 10:54:58   作者:一涯  
內部系統(tǒng)上線了一個發(fā)版記錄發(fā)版內容的功能,維護發(fā)版記錄的同事提出一個可以展示前后文本差異的優(yōu)化需求,?使的每次變更前可以確認新增了哪些,或者刪除了哪些內容,所以本文給大家介紹了基于JS實現(xiàn)文本比較差異,需要的朋友可以參考下

內部系統(tǒng)上線了一個發(fā)版記錄發(fā)版內容的功能。維護發(fā)版記錄的同事提出一個可以展示前后文本差異的優(yōu)化需求。 使的每次變更前可以確認新增了哪些,或者刪除了哪些內容。項目使用react。

另外,互聯(lián)網(wǎng)面試前刷八股+leetCode已經(jīng)是約定俗成的事情的,但一直覺得刷算法題只是為了應付面試。但是這個任務意識到之所以用不到,是因為習慣了三方庫,沒有三方庫,這些算法很有用。

預期結果

引入第三方插件jsdiff

github地址

官方demo

基本用法:

npm install diff --save

根據(jù)官方demo,常見的用法有三種:

分別對應提供的方法如下:

  • Diff.diffChars(oldStr, newStr[, options]) 

  • Diff.diffWords(oldStr, newStr[, options]) 

  • Diff.diffWordsWithSpace(oldStr, newStr[, options])

  • Diff.diffLines(oldStr, newStr[, options]) 

以diffChars為例,項目中按需引入如下:

import { diffChars } from "diff";

在項目中將其提取成一個組件:

 // .....
    const { oldStr, newStr } = props;

    useEffect(() => {
        const diff = diffChars(oldStr, newStr);
        console.log(diff, newStr);
        let span = null;
        const fragment = document.createDocumentFragment();
        const display = document.getElementById('content');
        diff.forEach((part) => {
            const color = part.added ? 'green' :
              part.removed ? 'red' : 'grey';
            span = document.createElement('span');
            span.style.color = color;
            if (color == "red") {
                span.style.textDecoration = "line-through";
            }
            if (color == "green") {
                span.style.background = "#48ff00";
            }
            span.appendChild(document
              .createTextNode(part.value));
            fragment.appendChild(span);
          });
          display.appendChild(fragment);
    }, [oldStr, newStr]);

//.....

對于接受展示內容的外層容器來說,需要注意: 對于換行符號 \n 需要使用<pre>標簽包裹才能保持文本的展示格式。如下

    return <>
        <pre><div id="content"></div></pre>
    </>;

關于jsdiff算法

An O(ND) Difference Algorithm and Its Variations

Eugene W. Myers • Algorithmica • Published 1986

The problems of finding a longest common subsequence of two sequences A and B and a shortest edit script for transforming A into B have long been known to be dual problems. In this paper, they are shown to be equivalent to finding a shortest/longest path in an edit graph. Using this perspective, a simple O(ND) time and space algorithm is developed where N is the sum of the lengths of A and B and D is the size of the minimum edit script for A and B. The algorithm performs well when differences are small (sequences are similar) and is consequently fast in typical applications. The algorithm is shown to have O(N +D expected-time performance under a basic stochastic model. A refinement of the algorithm requires only O(N) space, and the use of suffix trees leads to an O(NlgN +D ) time variation.

從上面的描述可知,這個算法的空間復雜度是O(N),時間復雜度是O(nLgN)

刷題常見的[求兩個字符串中最大子串及最大子序列]以及[最短編輯距離問題]

從這個庫可知,這些算法很有用。

以上就是JS實現(xiàn)文本比較差異的示例代碼的詳細內容,更多關于JS文本比較的資料請關注腳本之家其它相關文章!

相關文章

  • JavaScript實現(xiàn)簡單的計算器功能

    JavaScript實現(xiàn)簡單的計算器功能

    這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)簡單的計算器功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-03-03
  • 微信小程序實現(xiàn)左滑刪除效果源碼

    微信小程序實現(xiàn)左滑刪除效果源碼

    這篇文章主要給大家介紹了關于微信小程序實現(xiàn)左滑刪除效果的相關資料,左滑刪除效果在app的交互方式中十分流行,比如全民應用微信,文中給出了詳細的實現(xiàn)代碼,需要的朋友可以參考下
    2023-08-08
  • javascript 數(shù)據(jù)存儲的常用函數(shù)總結

    javascript 數(shù)據(jù)存儲的常用函數(shù)總結

    這篇文章主要介紹了javascript 數(shù)據(jù)存儲的常用函數(shù)總結的相關資料,需要的朋友可以參考下
    2017-06-06
  • 分享兩個手機訪問pc網(wǎng)站自動跳轉手機端網(wǎng)站代碼

    分享兩個手機訪問pc網(wǎng)站自動跳轉手機端網(wǎng)站代碼

    這篇文章主要介紹了分享兩個手機訪問pc網(wǎng)站自動跳轉手機端網(wǎng)站代碼,需要的朋友可以參考下
    2015-01-01
  • JavaScript位置參數(shù)實現(xiàn)原理及過程解析

    JavaScript位置參數(shù)實現(xiàn)原理及過程解析

    這篇文章主要介紹了JavaScript位置參數(shù)實現(xiàn)原理及過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-09-09
  • js實現(xiàn)簡易購物車功能

    js實現(xiàn)簡易購物車功能

    這篇文章主要為大家詳細介紹了js實現(xiàn)簡易購物車功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • 詳解適配器在JavaScript中的體現(xiàn)

    詳解適配器在JavaScript中的體現(xiàn)

    在日常開發(fā)中,很多時候會不經(jīng)意間寫出符合某種設計模式的代碼,而適配器其實在JavaScript中應該是比較常見的一種了。這篇文章主要介紹了適配器在JavaScript中的體現(xiàn) ,需要的朋友可以參考下
    2018-09-09
  • javascript css styleFloat和cssFloat

    javascript css styleFloat和cssFloat

    在寫js操作css的過程中發(fā)現(xiàn)float屬性在IE和firefox下對應的js腳本是不一樣的,IE下對應得是 styleFloat,firefox,chorme,safari下對應的是cssFloat,可用in運算符去檢測style是否包含此屬性。
    2010-03-03
  • [轉]去百度面試的javascript 收獲

    [轉]去百度面試的javascript 收獲

    前兩天去了百度面試,1面是很順利,2面基本是被問暈問傻問成了個白癡。沒去之前,自己覺得自己的js還是可以的,但是被考官問的基本變成了白癡。
    2009-04-04
  • electron項目中實現(xiàn)視頻下載保存到本地的方式

    electron項目中實現(xiàn)視頻下載保存到本地的方式

    這篇文章主要介紹了electron項目中實現(xiàn)視頻下載保存到本地的兩種實現(xiàn)方式,每種方式結合實例代碼給大家介紹的非常詳細,需要的朋友參考下吧
    2024-07-07

最新評論