js操作XML文件的實現(xiàn)方法兼容IE與FireFox
最近項目中用到了xml,需求是用戶安裝產品時先把一系列的數(shù)據保存到xml文件中,當執(zhí)行到最后一步時才寫入數(shù)據庫,這樣最大限度的減少了數(shù)據庫的訪問,于是不得不糾結在各瀏覽器的兼容性的問題(悲哀啊....)
進入正文 下面是一個xml文件 (createInstal.xml)
<?xml version="1.0" encoding="utf-8"?> <info> <Item> <id descrption="級別" name="1" f_chines="編號" t_chines="編號" english="id" value="1">編號</id> <levelname descrption="級別" name="" f_chines="級別名稱" t_chines="級別名稱" english="Level-Name" value="級別一">級別名稱</levelname> <decrption descrption="級別" name="" f_chines="級別描述" t_chines="級別描述" english="Level-Description" value="級別描述一">描述</decrption> <Tchines descrption="級別" name="" f_chines="繁體中文" t_chines="繁體中文" english="T-Chinese" value="級別一">繁體中文</Tchines> <english descrption="級別" name="" f_chines="英文名稱" t_chines="英文名稱" english="English" value="LevelOne">英文名稱</english> <獎項六 descrption="獎項" name="106" f_chines="獎項六" t_chines="獎項六" english="Worda-of-t" value="a"/> <獎項十一 descrption="獎項" name="111" f_chines="獎項十一" t_chines="獎項十一" english="11" value="0.05"/> <獎項十二 descrption="獎項" name="112" f_chines="獎項十二" t_chines="獎項十二" english="2222" value="0.04"/> <獎項十三 descrption="獎項" name="113" f_chines="獎項十三" t_chines="獎項十三" english="3333" value="0.85"/> <獎項一 descrption="獎項" name="101" f_chines="獎項一" t_chines="獎項一" english="Aword-of-a" value="0.90"/> </Item> </info>
為了能兼容IE與FF,寫如下幾個函數(shù)(loadxml.js):
var is_Ie =false; //是否為IE瀏覽器 if (window.ActiveXObject) { is_Ie =true; } //加載多瀏覽器兼容的xml文檔 function loadXml(xmlUrl) { var xmldoc =null; try { xmldoc =new ActiveXObject("Microsoft.XMLDOM"); } catch (e) { try { xmldoc = document.implementation.createDocument("", "", null); } catch (e) { alert(e.message); } } try { //關閉異步加載 xmldoc.async =false; xmldoc.load(xmlUrl); return xmldoc; } catch (e) { alert(e.message); } returnnull; } //將一個xml文檔格式的字符串換成xml文檔 function createXml(xmlText) { if (!xmlText) { returnnull; try { var xmldocm =new ActiveXObject("Microsoft.XMLDOM"); xmldocm.loadXML(xmlText); return xmldocm; } catch (e) { try { returnnew DOMParse().parseFromString(xmlText, "text/xml"); } catch (e) { returnnull; } } } } //獲取節(jié)點及其子節(jié)點的文本 function getXmlText(oNode) { if (oNode.text) {//IE return oNode.tex; } var sText =""; for (var i =0; i < oNode.childNodes.length; i++) { //遍歷子節(jié)點 if (oNode.childNodes[i].hasChildNodes()) { //是否有子節(jié)點 sText += getXmlText(oNode.childNodes[i]); } else { sText += oNode[i].childNodes.nodeValue; } } return sText; } //獲取節(jié)點及其子節(jié)點的字符串標識 function getXml(oNode) { if (oNode.xml) {//IE return oNode.xml; } var serializer =new XMLSerializer(); return serializer.serializeToString(oNode); } //獲取指定節(jié)點的文本(注意:也可以用oNode.childNodes[0].nodeValue來獲取節(jié)點的文本信息,這樣就不用考慮瀏覽器的問題了oNodeoNode) function getxmlnodeText(oNode) { if (is_Ie) { return oNode.text; } else { if (oNode.nodeType ==1) return oNode.textContent; } } //獲取指定節(jié)點的屬性值 function getxmlnodeattribute(oNode, attrName) { if (is_Ie) { return oNode.getAttribute(attrName); } else { if (oNode.nodeType ==1|| oNode.nodeType =="1")return oNode.attributes[attrName].value;return"undefined";}}
ok IE與FF 不再是問題,具體的操作方法如下:
var docum = loadxml("createInstal.xml");//加載一個xml文件 var root = docum.documentElement;//根節(jié)點 var nodelist = root.getElementsByTagName("Items"); for(var i=0;i<nodelist[0].childNodes.length;i++) { var attr = getxmlnodeattribute(nodeList[0].childNodes[i], "descrption");//獲取這個節(jié)點的descrption屬性 if(attr != "undefined")//目的是兼容FF瀏覽器 { alert(attr); } }
這樣就能保證IE與FF的兼容,(目前谷歌瀏覽器沒有辦法用這種方法兼容,還待修改)
另外說下FireFox獲取xml的兩種方法:
firefox中JS讀取XML文件
在網上搜“firefox中JS讀取XML文件”的方法,找了半天,好 多都是問了沒人答的??吹揭欢殉绦騿T在抱怨firefox:“除了累死程序員沒什么好處。”,言歸正傳。firefox不支持ie中的 ActiveXObject對象,要得到一個XML DOM有以下2種方法:
1、document.implementation.createDocument("", "", null);
2、window.XMLHttpRequest
示例:1、var dom=document.implementation.createDocument("", "", null);
dom.async=false;
dom.load("test.xml");//dom就是xml對象了。
2、var oXmlHttp = new XMLHttpRequest() ;
oXmlHttp.open( "GET", "test.xml", false ) ;
oXmlHttp.send(null) ;
//oXmlHttp.responseXML就是xml對象了。
注意:
1、火狐解析xml文檔
2、火狐瀏覽器和ie解析xml不一樣節(jié)點的值用textContent。
3、并且他會在有的層次child節(jié)點(即使用childNodes時)前后都加上"\n"換行符。(這個搞不清楚為什么,用firebug調試的時候就是這個樣子,所以寫過的代碼最好測試一下,換個環(huán)境就不對了) ,也就是說第1個節(jié)點是"\n",第2個節(jié)點才是真正的
第一個節(jié)點。 第3個節(jié)點是"\n",第4個節(jié)點才是真正的第二個節(jié)點。
根據上述的火狐的情況,我這里有個例子避免了使用childNodes,而達到兼容性:點擊進入
以上就是小編為大家?guī)淼膉s操作XML文件的實現(xiàn)方法兼容IE與FireFox全部內容了,希望大家多多支持腳本之家~
相關文章
新年快樂! javascript實現(xiàn)超級炫酷的3D煙花特效
這篇文章主要為大家詳細介紹了javascript實現(xiàn)超級炫酷的3D煙花特效,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-01-01將HTML格式的String轉化為HTMLElement的實現(xiàn)方法
本節(jié)主要介紹了將HTML格式的String轉化為HTMLElement的實現(xiàn)方法,需要的朋友可以參考下2014-08-08layer彈出的iframe層在執(zhí)行完畢后關閉當前彈出層的方法
今天小編就為大家分享一篇layer彈出的iframe層在執(zhí)行完畢后關閉當前彈出層的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08基于JavaScript實現(xiàn)線性漸變的高斯模糊效果
這篇文章主要為大家詳細介紹了高斯模糊算法以及線性漸變的高斯模糊算法的原理,并通過一個小demo展示了如何實現(xiàn)y方向上線性漸變的高斯模糊效果,需要的可以了解下2024-01-01