Javascript格式化並高亮xml字元串

来源:https://www.cnblogs.com/onlyfu/archive/2018/08/13/9465691.html
-Advertisement-
Play Games

Javascript格式化並高亮xml字元串 兩個關鍵點 1. 使用DOMParser解析xml 2. 遞歸遍歷xml樹,按格式輸出每一個節點 關於使用DOMParser 此方法目前在IE9以上和其它瀏覽器里都是支持的,所以這裡不在寫關於IE9以下不支持的情況, 具體的使用請跳轉 "https:// ...


Javascript格式化並高亮xml字元串

兩個關鍵點

  1. 使用DOMParser解析xml
  2. 遞歸遍歷xml樹,按格式輸出每一個節點

關於使用DOMParser

此方法目前在IE9以上和其它瀏覽器里都是支持的,所以這裡不在寫關於IE9以下不支持的情況, 具體的使用請跳轉
https://developer.mozilla.org/en-US/docs/Web/API/DOMParser

Javascript代碼

/**
 * 格式化xml
 * @param content
 * @returns {*}
 */
this.parse_xml = function(content) {
    let xml_doc = null;
    try {
        xml_doc = (new DOMParser()).parseFromString(content.replace(/[\n\r]/g, ""), 'text/xml');
    } catch (e) {
        return false;
    }

    function build_xml(index, list, element) {
        let t = [];
        for (let i = 0; i < index; i++) {
            t.push('&nbsp;&nbsp;&nbsp;&nbsp;');
        }
        t = t.join("");
        list.push(t + '&lt;<span class="code-key">'+ element.nodeName +'</span>&gt;\n');
        for (let i = 0; i < element.childNodes.length; i++) {
            let nodeName = element.childNodes[i].nodeName;
            if (element.childNodes[i].childNodes.length === 1) {
                let value = element.childNodes[i].childNodes[0].nodeValue;
                let value_color = !isNaN(Number(value)) ? 'code-number' : 'code-string';
                let value_txt = '<span class="'+ value_color +'">' + value + '</span>';
                let item = t + '&nbsp;&nbsp;&nbsp;&nbsp;&lt;<span class="code-key">' + nodeName +
                    '</span>&gt;' + value_txt + '&lt;/<span class="code-key">' + nodeName + '</span>&gt;\n';
                list.push(item);
            } else {
                build_xml(++index, list, element.childNodes[i]);
            }
        }
        list.push(t + '&lt;/<span class="code-key">'+ element.nodeName +'</span>&gt;\n');
    }

    let list = [];
    build_xml(0, list, xml_doc.documentElement);

    return list.join("");
};

css

.code-string{color:#993300;}
.code-number{color:#cc00cc;}
.code-boolean{color:#000033;}
.code-null{color:magenta;}
.code-key{color:#003377;font-weight:bold;}

效果

註意

DOMParser在解析xml時,如果xml字元串里有些特殊的字元,解出來的樹節點有些是不需要的,會倒置遍歷節點失敗。

最後

些方法已用於YuiAPI


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、前言 在一次對比oracle和greenplum查詢性能過程中,由於greenplum查詢性能不理想,因此進行定位分析,提升greenplum的查詢性能 二、環境信息 初始情況下,搭建一個小的集群,進行性能測試 PS:由於要求greenplum中的表數據類型和源表類型一直,且索引一致。所以所有字 ...
  • 本地安裝及網頁測試 下載地址 : https://www.mongodb.com/download-center#community 可以在MongoDB官網選擇Community Server版本下載,但是它似乎經常沒有響應。可以在這裡直接選擇需要的版本下載,要在Windows下安裝可以直接選ms ...
  • 1、思維模式轉變的催化劑是大量新技術的誕生,它們能夠處理大數據分析所帶來的3個V的挑戰。扎根於開源社區,Hadoop已經是目前大數據平臺中應用率最高的技術,特別是針對諸如文本、社交媒體訂閱以及視頻等非結構化數據。 2、除分散式文件系統之外,伴隨Hadoop一同出現的還有進行大數據集處理MapRedu ...
  • 透視數據實際上就是行狀態轉為例狀態 先加一張測試表 把這張表查出來 我們將 custid行轉換成例 sql server 還支持一個子句用於 行轉列 PIVOT 是以FROM內嵌 表表達式實現的 PIVOT (數據行) for 要轉的列 IN (轉那幾個數據) ...
  • 很多人都知道大數據很火,就業很好,薪資很高,想往大數據方向發展。但該學哪些技術,學習路線是什麼樣的呢? 大數據的三個發展方向,平臺搭建/優化/運維/監控、大數據開發/設計/架構、數據分析/挖掘。 先說一下大數據的4V特征: 數據量大,TB->PB 數據類型繁多,結構化、非結構化文本、日誌、視頻、圖片 ...
  • 我有一個Objective-C協議,我試圖在Swift類中實現。例如: 當我嘗試在這樣的Swift類中符合它時: 我得到以下可怕的編譯器錯誤: Type '' cannot conform to protocol '' because it has requirements that cannot ...
  • 1.要用bootStrap這個框架就必須要重載它的class類,也就是說class要一樣 代碼如下: 有疑問的可以在下麵留言,歡迎大家一起交流 1.1動態模態框 1.2靜態模態框 ...
  • 1.jQuery的框架的驗證:validate框架 Jquery Validate 驗證規則 (1)required:true 必輸欄位(2)remote:”check.PHP” 使用ajax方法調用check.php驗證輸入值(3)email:true 必須輸入正確格式的電子郵件(4)url:tr ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...