【001】JS解析,反解析XML的一些问题
JS解析,反解析 XML 的一些问题
2016-03-25 15:38:28 星期五
文章底部下面有提供把 字符串 变成 XML 对象的方法。
该方法,在 Chrome48 ,FireFox ,IE11 测试成功!
1. ** stackoverflow XML有命名空间怎么办???**
但是 如果 XML节点,有命名空间,如 <namespace:Node></namespace:Node>
解析就报错,这个报错不是有因为 这个解析方法的问题,而是因为XML格式规定的。
如果XML有使用命名空间的,必须在 root 根节点声明,否则就报错。
如下:
<definitions xmlns="http://www.omg.org/spec/BPMN/20100524/MODEL" xmlns:bpmndi="http://www.omg.org/spec/BPMN/20100524/DI"
xmlns:omgdc="http://www.omg.org/spec/DD/20100524/DC" xmlns:omgdi="http://www.omg.org/spec/DD/20100524/DI"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:activiti="http://activiti.org/bpmn"
id="review-definitions" typeLanguage="http://www.w3.org/2001/XMLSchema"
expressionLanguage="http://www.w3.org/1999/XPath" targetNamespace="http://activiti.org/bpmn20">
<activiti:field name="type">
<activiti:expression>Shell</activiti:expression>
</activiti:field>
<bpmndi:BPMNDiagram id="BPMNDiagram_ryantest130">
<bpmndi:BPMNPlane bpmnElement="ryantest130" id="BPMNPlane_ryantest130">
<BPMNShape id="BPMNShape_a22f130e-fcfc-411f-8323-f8d0b482d01f"
bpmnElement="a22f130e-fcfc-411f-8323-f8d0b482d01f">
<Bounds height="60" width="60" x="224" y="187"/>
</BPMNShape>
<BPMNShape id="BPMNShape_6fa449e4-bfd8-499d-bac0-de62e7b39c4a"
bpmnElement="6fa449e4-bfd8-499d-bac0-de62e7b39c4a">
<Bounds height="60" width="60" x="473" y="194"/>
</BPMNShape>
<BPMNShape id="BPMNShape_daf837d7-daeb-4c3b-b820-60cb84b82ddd"
bpmnElement="daf837d7-daeb-4c3b-b820-60cb84b82ddd">
<Bounds height="60" width="60" x="635" y="197"/>
</BPMNShape>
<BPMNShape id="BPMNShape_e2df6eed-3b1d-4a6e-b674-8e13364cde29"
bpmnElement="e2df6eed-3b1d-4a6e-b674-8e13364cde29">
<Bounds height="60" width="60" x="227" y="266"/>
</BPMNShape>
</bpmndi:BPMNPlane>
</bpmndi:BPMNDiagram>
</definitions>
2.有命名空间的节点,在各个浏览器下有兼容性问题
Firefox 下:
xmlDoc.getElementTagName('namespace:Node')
这样的方法,在 FireFox 下可以 获取到子节点, 但是,但是 Chrome48 下,拿不到
Chrome48 下:
xmlDoc.getElementTagName('Node')
需要去掉命名空间才可以获取到该节点
提供的解决方案:可以重写 XMLDocument.proptyoe.getElementsTagName
let node = xml.getElementsByTagName('expression');
if (!node.length) node = xml.getElementsByTagName('activiti:expression');
解析 字符串 到 XML对象的方法
var XML = (function() {
/**
* 把字符串转换成 XMLDOC 对象
* @param {[type]} xmlStr [description]
* @return {[type]} [description]
*/
function str2xml(xmlStr) {
//跨浏览器,ie和火狐解析xml使用的解析器是不一样的。
var xmlStrDoc = null;
if (window.DOMParser) { // Mozilla Explorer
var parser = new DOMParser();
xmlStrDoc = parser.parseFromString(xmlStr, "text/xml");
} else { // Internet Explorer
xmlStrDoc = new ActiveXObject("Microsoft.XMLDOM");
xmlStrDoc.async = "false";
xmlStrDoc.loadXML(xmlStr);
}
return xmlStrDoc;
}
/*===============================XML2JSON START==========================*/
/**
* XML 转成 JSON 对象
* @param {[type]} xml [description]
* @return {[type]} [description]
*/
function xml2Json(xml) {
// Create the return object
var obj = {};
if (xml.nodeType == 1) { // element
// do attributes
if (xml.attributes.length > 0) {
obj["@attributes"] = {};
for (var j = 0; j < xml.attributes.length; j++) {
var attribute = xml.attributes.item(j);
obj["@attributes"][attribute.nodeName] = attribute.nodeValue;
}
}
} else if (xml.nodeType == 3) { // text
obj = xml.nodeValue;
}
// do children
if (xml.hasChildNodes()) {
for (var i = 0; i < xml.childNodes.length; i++) {
var item = xml.childNodes.item(i);
var nodeName = item.nodeName;
if (typeof(obj[nodeName]) == "undefined") {
obj[nodeName] = xml2Json(item);
} else {
if (typeof(obj[nodeName].length) == "undefined") {
var old = obj[nodeName];
obj[nodeName] = [];
obj[nodeName].push(old);
}
obj[nodeName].push ? obj[nodeName].push(xml2Json(item)) : obj[nodeName] = xml2Json(item);
}
}
}
return obj;
};
return {
str2xml: str2xml,
xml2Json: xml2Json,
}
})();
【001】JS解析,反解析XML的一些问题的更多相关文章
- js中递归解析xml
xml结构: <RightMenuItems> <Item Code="New" Name="新建" GroupCode="Edi ...
- zepto.js 源码解析
http://www.runoob.com/w3cnote/zepto-js-source-analysis.html Zepto是一个轻量级的针对现代高级浏览器的JavaScript库, 它与jqu ...
- 谷歌地图地理解析和反解析geocode.geocoder详解
地址解析就是将地址(如:贵州省贵阳市)转换为地理坐标(如经度:106.71,纬度:26.57)的过程. 地理反解析和上面的过程相反是将地理坐标(如纬度:26.57,经度:106.71)转换为地址(中国 ...
- angularjs-googleMap googleMap api地址解析与反解析
1.js:根据地址得到经纬度var myplace=$scope.place;//获取输入的地址var geocoder = new google.maps.Geocoder();//创建geocod ...
- SAX解析和生成XML文档
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本人声明.否则将追究法律责任. 作者: 永恒の_☆ 地址: http://blog.csdn.net/chenghui031 ...
- js的预解析
在ES6之前,变量使用var声明,会存在变量的预解析(函数也有预解析).ES6引了let和const,但是现阶段ES6并没有完全普及,而且很多比较老的代码都还是按照ES5的标准甚至是ES3的标准来书写 ...
- 谷歌地图地理解析和反解析geocode.geocoder详解(转)
谷歌地图地理解析和反解析geocode.geocoder详解 谷歌Geocoder服务 实例代码 地址解析就是将地址(如:贵州省贵阳市)转换为地理坐标(如经度:106.71,纬度:26.57)的过程. ...
- underscore.js源码解析(五)—— 完结篇
最近公司各种上线,所以回家略感疲惫就懒得写了,这次我准备把剩下的所有方法全部分析完,可能篇幅过长...那么废话不多说让我们进入正题. 没看过前几篇的可以猛戳这里: underscore.js源码解析( ...
- underscore.js源码解析(三)
最近工作比较忙,做不到每周两篇了,周末赶着写吧,上篇我针对一些方法进行了分析,今天继续. 没看过前两篇的可以猛戳这里: underscore.js源码解析(一) underscore.js源码解析(二 ...
随机推荐
- 阿里巴巴Java开发手册(详尽版)-个人未注意到的知识点(转)
转自 https://blog.csdn.net/u013039395/article/details/86528164 一.编程规约 (一) 命名风格 [强制]代码中的命名只可用英文方式 [强制]类 ...
- 开源方案搭建可离线的精美矢量切片地图服务-4.Mapbox样式设计
项目成果展示(所有项目文件都在阿里云的共享云虚拟主机上,访问地图可以会有点慢,请多多包涵). 01:中国地图:http://test.sharegis.cn/mapbox/html/3china.ht ...
- npm run build之后生成的dist如何扔到服务器运行(npm run build之后如何本地运行)
运行npm run build之后,会生成一个dist文件夹,里面的目录结构大概是这样的: 生成完的文件我们怎么来运行呢?直接在本地打开inde.html是无法运行的,打包的时候有提示: 构建文件应该 ...
- 利用CEF山寨一个翻译器
起因 在某些情况下,有将从某种类型的语言翻译成另一种类型语言的需求.比如在生成实体时,可能需要将中文名称转换成英文.于是利用CEFSharp山寨了一个翻译器.效果图如下: CEF简介 CEF全称为Ch ...
- 神奇的datetime和datetime,一毫秒引发的血案
今天才发现C#的datetime和sqlserver的daetime是多么的不一样.首先最小和最大值不一样这是众所周知的,其实精度也是一大坑. 比如 DateTime.Today.AddMillise ...
- C# NPOI 导出Execl 工具类
NPOI 导出Execl 自己单独工具类 详见代码 using System; using System.Collections.Generic; using System.Linq; using S ...
- 【学习笔记】--- 老男孩学Python,day16-17 初识面向对象,类名称空间,查询顺序,组合
面向过程 VS 面向对象 面向过程的程序设计的核心是过程(流水线式思维),过程即解决问题的步骤,面向过程的设计就好比精心设计好一条流水线,考虑周全什么时候处理什么东西. 优点是:极大的降低了写程序的复 ...
- vue的v-html插值样式问题
content使用html插入文本和图片 使用scoped样式,渲染失败. 原因: 解决方案: 采用全局样式 或另外再加style标签单独渲染
- .NET中的异步编程
开篇 异步编程是程序设计的重点也是难点,还记得在刚开始接触.net的时候,看的是一本c#的Winform实例教程,上面大部分都是教我们如何使用Winform的控件以及操作数据库的实例,那时候做的基本都 ...
- php写入文件fwrite() 函数用法
在php中,php fwrite() 函数是用于写入文件(可安全用于二进制文件).说的简单点,就是在一个文件中,添加新的内容,本篇文章收集总结了几篇关于php写入文件fwrite() 函数用法的总结, ...