【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 Explorervar parser = new DOMParser();xmlStrDoc = parser.parseFromString(xmlStr, "text/xml");} else { // Internet ExplorerxmlStrDoc = 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 objectvar obj = {};if (xml.nodeType == 1) { // element// do attributesif (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) { // textobj = xml.nodeValue;}// do childrenif (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源码解析(二 ...
随机推荐
- 三种数据库访问——原生JDBC
原生的JDBC编程主要分一下几个步骤: (原生的JDBC编程指,仅应用java.sql包下的接口和数据库驱动类编程,而不借助任何框架) 1. 加载JDBC驱动程序: 2. 负责管理JDBC驱动程序的类 ...
- c#基础学习(0806)之抽象类实现多态
首先,要判断是否使用抽象类,可以从下面两个方面进行判断: 1.是不是需要被实例化 2.父类中有没有默认的实现 如果不需要被实例化,父类中没有默认的实现,则用抽象类(否则用虚方法来实现) 下面举个简单的 ...
- linq之多表连接
1.左连接: var LeftJoin = from emp in ListOfEmployees join dept in ListOfDepartment on emp.DeptID equals ...
- BG.Hive - part1
1. Hive架构 What is hive? Facebook,https://en.wikipedia.org/wiki/Apache_Hive a> 一种工具,可以通过SQL轻松的访问数据 ...
- Hadoop shell 一查就会
Hadoop shell 命令有三种格式 hdfs + dfs (必须是dfs) Hadoop + dfs Hadoop + df 命令 说明 hadoop 版本查看 hadoop version h ...
- Java生成xlsx格式的excel文件
xlsx格式的写入的数据量据说有百万级,结合实际需要该格式. public static void main(String[] args) throws Exception { OutputStrea ...
- python学习之老男孩python全栈第九期_day013知识点总结
# l = [1,2,3]# 索引# 循环 for # list # dic # str # set # tuple # f = open() # range() # enumerate'''prin ...
- BZOJ4675: 点对游戏
传送门 考虑每一对幸运点对的贡献,假设有 \(v\) 对 一共可以选择 \(x\) 个点,总共 \(n\) 个点 那么答案就是 \[v\times\frac{A_{n-2}^{x-2}x(x-1)}{ ...
- 【代码笔记】iOS-iphone开发之获取系统字体
代码: - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view. NS ...
- JavaScript--浅谈DOM操作
JavaScript之浅谈DOM操作 1.理解DOM: DOM(Document Object Model ,文档对象模型)一种独立于语言,用于操作xml,html文档的应用编程接口. 怎么说,我从两 ...