[原创]HTML Diff,php版本,文本对比(标记出两个HTML的差异)
3. [代码][JavaScript]代码 跳至
/* * Compare str * @example var result = htmldiff.compare('str1','str2'); * * */ var htmldiff = { MODE_CHARACTER: 1,MODE_TAG: 2,MODE_WHITESPACE: 3, ACTION_EQUAL: 1,ACTION_DELETE: 2,ACTION_INSERT: 3,ACTION_NONE: 4,ACTION_REPLACE: 5, specialCaseOpeningTags: new Array('\\s]+', '\\s]+', '\\s]+', '\\s]+', '\\s]+', '\\s]+', '\\s]+', '\\s]+', '\\s]+', '\\s]+'), specialCaseClosingTags: new Array('', '', '', '', '', '', '', '', '', ''), content: '', wordIndices: '', oldWords: '',newWords: '', compare: function(str1, str2) { this.content = new Array(); this.wordIndices = new Array(); this.oldWords = this.ConvertHtmlToListOfWords(str1); this.newWords = this.ConvertHtmlToListOfWords(str2); this.wordIndices = this.IndexNewWords(this.newWords); var b = this.Operations(); for (var c = 0; c < b.length; c++) { var d = b[c]; this.PerformOperation(d); } return this.content.join(''); }, Operations: function() { var d = 0; var j = 0; var a = new Array(); var f = this.MatchingBlocks(); f.push(this.Match(this.oldWords.length, this.newWords.length, 0)); for (var i = 0; i < f.length; i++) { var g = f[i]; var b = (d == g.StartInOld); var h = (j == g.StartInNew); var c = this.ACTION_NONE; if (b == false && h == false) c = this.ACTION_REPLACE; else { if (b == true && h == false) c = this.ACTION_INSERT; else { if (b == false && h == true) c = this.ACTION_DELETE; else c = this.ACTION_NONE; } } if (c != this.ACTION_NONE) a.push(this.Operation(c, d, g.StartInOld, j, g.StartInNew)); if (g.length != 0) a.push(this.Operation(this.ACTION_EQUAL, g.StartInOld, g.EndInOld(), g.StartInNew, g.EndInNew())); d = g.EndInOld(); j = g.EndInNew(); } return a; }, MatchingBlocks: function() { var a = new Array(); this.FindMatchingBlocks(0, this.oldWords.length, 0, this.newWords.length, a); return a; }, FindMatchingBlocks: function(c, b, f, e, d) { var a = this.FindMatch(c, b, f, e); if (a != null) { if (c < a.StartInOld && f < a.StartInNew) this.FindMatchingBlocks(c, a.StartInOld, f, a.StartInNew, d); d.push(a); if (a.EndInOld() < b && a.EndInNew() < e) this.FindMatchingBlocks(a.EndInOld(), b, a.EndInNew(), e, d); } }, FindMatch: function(l, e, b, k) { var f = l; var m = b; var n = 0; var c = new Array(); for (var i = l; i < e; i++) { var d = new Array(); var h = this.oldWords[i]; if (!this.wordIndices[h]) { c = d; continue; } for (var g = 0; g < this.wordIndices[h].length; g++) { var a = this.wordIndices[h][g]; if (a < b) continue; if (a >= k) break; newMatchLength = (c[a - 1] ? c[a - 1] : 0) + 1; d[a] = newMatchLength; if (newMatchLength > n) { f = i - newMatchLength + 1; m = a - newMatchLength + 1; n = newMatchLength; } } c = d; } return n != 0 ? this.Match(f, m, n) : null; }, IndexNewWords: function(d) { var b = new Array(); for (var i = 0; i < d.length; i++) { var c = d[i]; if (b[c]) b[c].push(i); else b[c] = [i]; } return b; }, ConvertHtmlToListOfWords: function(b) { var f = this.MODE_CHARACTER; var e = ''; var d = new Array(); for (var i = 0; i < b.length; i++) { var c = b[i]; switch (f) { case this.MODE_CHARACTER: if (this.IsStartOfTag(c)) { if (e) d.push(e); e = '<'; f = this.MODE_TAG; } else { if (this.IsWhiteSpace(c)) { if (e) d.push(e); e = c; f = this.MODE_WHITESPACE; } else {console.log(e ); if (this.isNaW(e + c)) { if (e) d.push(e); e = c; } else e = e + c; } } break; case this.MODE_TAG: if (this.IsEndOfTag(c)) { e = e + '>'; d.push(e); e = ''; if (this.IsWhiteSpace(c)) f = this.MODE_WHITESPACE; else f = this.MODE_CHARACTER; } else e = e + c; break; case this.MODE_WHITESPACE: if (this.IsStartOfTag(c)) { if (e) d.push(e); e = '<'; f = this.MODE_TAG; } else { if (this.IsWhiteSpace(c)) e = e + c; else { if (e) d.push(e); e = c; f = this.MODE_CHARACTER; } } break; default: break; } } if (e) d.push(e); return d; }, PerformOperation: function(a) { switch (a.Action) { case this.ACTION_EQUAL: this.ProcessEqualOperation(a); break; case this.ACTION_DELETE: this.ProcessDeleteOperation(a, 'diffdel'); break; case this.ACTION_INSERT: this.ProcessInsertOperation(a, 'diffins'); break; case this.ACTION_NONE: break; case this.ACTION_REPLACE: this.ProcessReplaceOperation(a); break; default: break; } }, ProcessReplaceOperation: function(a) { this.ProcessDeleteOperation(a, 'diffmod'); this.ProcessInsertOperation(a, 'diffmod'); }, ProcessInsertOperation: function(b, a) { var c = this.array_slice(this.newWords, b.StartInNew, b.EndInNew); this.InsertTag('ins', a, c); }, ProcessDeleteOperation: function(b, a) { var c = this.array_slice(this.oldWords, b.StartInOld, b.EndInOld); this.InsertTag('del', a, c); }, ProcessEqualOperation: function(b) { var a = this.array_slice(this.newWords, b.StartInNew, b.EndInNew); this.content.push(a.join('')); }, preg_match_array: function(b, e) { var a = 0; for (var i = 0; i < b.length; i++) a |= (new RegExp(b[i])).test(e); return a; }, InsertTag: function(j, h, f) { while (true) { if (f.length == 0) break; var b = this.ExtractConsecutiveWords(f, false); var c = b.items; f = b.words; var a = ''; var e = false; if (c.length != 0) { var g = this.WrapText(c.join(''), j, h); this.content.push(g); } else { if ( !! this.preg_match_array(this.specialCaseOpeningTags, f[0])) { a = ''; if (j == 'del') f.shift(); } else { if (this.in_array(f[0], this.specialCaseClosingTags)) { a = ''; e = true; if (j == 'del') f.shift(); } } } if (f.length == 0 && a.length == 0) break; if (e) { var d = this.ExtractConsecutiveWords(f, true); f = d.words; this.content.push(a + d.items.join('')); } else { var d = this.ExtractConsecutiveWords(f, true); f = d.words; this.content.push(d.items.join('') + a); } } }, in_array: function(b, c) { for (var i = 0; i < c.length; i++) { if (c[i] == b) return true; } return false; }, WrapText: function(c, b, a) { return '<' + b + ' class="' + a + '">' + c + ''; }, ExtractConsecutiveWords: function(d, f) { var e = false; for (var b = 0; b < d.length; b++) { var c = d[b]; if (f ? !this.IsTag(c) : !!this.IsTag(c)) { e = b; break; } } if (e !== false) { var a = this.array_slice(d, 0, e); if (e > 0) d.splice(0, e); return {items: a,words: d}; } else { a = d; d = new Array(); return {items: a,words: d}; } }, IsTag: function(b) { var a = this.IsOpeningTag(b) || this.IsClosingTag(b); return a; }, IsOpeningTag: function(a) { return /^\s*]+>\s*$/.test(a); }, IsClosingTag: function(a) { return /^\s*]+>\s*$/.test(a); }, IsStartOfTag: function(a) { return a == "<"; }, IsEndOfTag: function(a) { return a == ">"; }, IsWhiteSpace: function(a) { return /\s/.test(a); }, isNaW: function(b) { return /[^\x00-\x80]/.test(b); }, array_slice: function(a, b, c, d) { return a.slice(b, c); }, Match: function(b, d, a) { var c = { StartInOld: b, StartInNew: d, Size: a }; c.EndInOld = function() { return b + a; }; c.EndInNew = function() { return d + a; }; return c; }, Operation: function(c, b, a, f, d) { var e = { Action: c, StartInOld: b, EndInOld: a, StartInNew: f, EndInNew: d }; return e; } };

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

身為一個php學習和開發者,怎麼能不了解其歷史?以下php中文網帶領php愛好者們一起回顧下php各個歷史版本。

寶塔面板是一款功能強大、使用方便的伺服器管理面板,可幫助使用者輕鬆管理網站、資料庫、FTP等服務。在使用寶塔面板的過程中,有時會需要切換PHP版本來適應不同的網站需求。本文將為大家提供一個PHP版本切換的簡易指南,同時提供具體的程式碼範例,以協助讀者快速完成PHP版本切換的操作。首先,我們需要登入寶塔面板,進入網站設定頁面。在左側導覽列找到「網站」選項,並點

寶塔面板(BTPanel)是一款強大而易用的伺服器管理面板,可協助使用者輕鬆管理伺服器、網站和資料庫等服務。身為網站開發者或管理員,掌握寶塔面板中PHP版本切換的技巧十分重要。在本文中,將分享如何在寶塔面板中操作、切換PHP版本的方法,並提供具體的程式碼範例,幫助讀者更好地掌握這項技能。 1.登入寶塔面板首先,在瀏覽器中輸入伺服器IP位址或域名,加上寶塔

Eclipse是一款廣泛使用的整合開發環境(IDE),可用於開發各種程式語言的專案。在使用Eclipse開發PHP專案時,有時候需要更新PHP版本以適應新功能或修復bug。本文將介紹如何在Eclipse中更新PHP版本,並提供具體的程式碼範例。一、更新PHP版本的準備工作在更新PHP版本之前,我們需要確保已經安裝了Eclipse以及PHP的開發環境。另外,

PHP版本NTS的意義與重要性PHP(HypertextPreprocessor)是一種廣泛使用的開源伺服器端腳本語言,被用來開發動態網頁。 PHP的版本包括NTS(Non-ThreadSafe)和TS(ThreadSafe)兩種。在本文中,我們將重點討論NTS版本的含義和重要性,並提供一些具體的程式碼範例。 NTS版本是指PHP的非線程安全版本,其設計初衷

PHP函數版本更新的影響:新功能的影響:引入新特性,方便開發複雜任務。修復錯誤的影響:改進函數行為,提高程式碼穩定性。行為變更的影響:最具破壞性,需更新使用函數的程式碼。最佳實務:在測試環境測試更新、檢查互動程式碼、更新受影響依賴項。

在使用PHP開發網站或應用程式時,版本升級是一項必要的工作,因為每個版本都會帶來新的功能和修復已知問題。但是,PHP版本升級也會引入新的錯誤,因為新版本可能不再支援舊版的功能或語法。在本文中,我們將介紹如何處理PHP版本升級所帶來的錯誤,以確保應用程式的正常運作。 1.備份應用程式和伺服器在進行PHP版本升級之前,必須備份應用程式和伺服器。備份應用程式可以在出

PHP7版本新功能及對小程式開發的影響隨著科技的不斷發展,網路產業也日新月異。近年來,小程式成為了行動應用程式開發的熱門話題。同時,PHP7版本的發布也成為了開發者矚目的焦點。本文將探討PHP7版本的新特性,並分析它對小程式開發的影響。一、PHP7版本新特性PHP7版本作為PHP語言的重大更新,帶來了許多新的特性與效能上的提升。以下是幾個重要的新功能:性
