但是是XML字串,則在兩種瀏覽器下就會有所不同,IE下可以直接使用LoadXML方法解析XML字串,而在FF下則要使用DOMParser 對象的parseFromString() 方法即
var oParser=new DOMParser();
xmlDoc=oParser.parseFromString(xmlStr,"text/xml");
為了在兩種瀏覽器中能通用,我想到了javascritp的發生異常的處理方式,就是try...catch...
複製代碼 代碼如下:function toXML(strxml){
try{
xmlDoc = new ActiveXObject("Microsoft.XMLDOM");
xmlDoc.loadXML(strxml);
}
catch(e){
var oParser=new DOMParser();
xmlDoc=oParser.parseFromString(strxml,"text/xml");
}
return xmlDoc;
}
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]
看,不管在ie還是ff中都彈出了1400吧!! 複製代碼 代碼如下:function FormatToXml(strXml){
var isIE = function(){
var IE = /msie/i.test(navigator.userAgent);
return IE;
}
var Exc = function(){
var XmlDoc = null;
if (isIE())
{
XmlDoc = new ActiveXObject("Microsoft.XMLDOM");
XmlDoc.loadXML(strXml);
}else{
//FireFox2.0、Safari2.0
XmlDoc = (new DOMParser()).parseFromString(strXml, "text/xml");
}
return XmlDoc;
}
return Exc();
}
功能是一樣的,都是為了在ie和ff中處理xml字串的解析問題。不過在無憂上有些人說xml字串要有<?xml version="1.0" encoding="gb2312"?>,可我測試後若有xml version="1.0" encoding="gb2312"?>,解析結果不一致,所以我上面的例子沒有加這些字元。