爱游戏全站app官网入口-爱游戏官网

如何实现javascript格式化并高亮xml字符串 -爱游戏全站app官网入口

2023-06-14,

这篇文章给大家分享的是有关如何实现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('    ');
    }
    t = t.join("");
    list.push(t   '<'  element.nodename  '>\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 = ''   value   '';
        let item = t   '    <'   nodename  
          '>'   value_txt   '</'   nodename   '>\n';
        list.push(item);
      } else {
        build_xml(  index, list, element.childnodes[i]);
      }
    }
    list.push(t   '</'  element.nodename  '>\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字符串里有些特殊的字符,解出来的树节点有些是不需要的,会倒置遍历节点失败。

感谢各位的阅读!关于“如何实现javascript格式化并高亮xml字符串”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

网站地图