web前端之JavaScript高级程序设计八:JavaScript 与 XML

web前端之JavaScript高级程序设计八:JavaScript 与 XML

曾几何时, XML 一度成为存储和通过因特网传输结构化数据的标准。透过 XML 的发展,能够清晰地看到 Web 技术发展的轨迹。 DOM 规范的制定,不仅是为了方便在 Web 浏览器中使用XML,也是为了在桌面及服务器应用程序中处理 XML 数据。此前,由于浏览器无法解析 XML 数据,很多开发人员都要动手编写自己的 XML 解析器。而自从 DOM 出现后,所有浏览器都内置了对 XML 的原生支持(XML DOM),同时也提供了一系列相关的技术支持。

IE8 及之前版本中的XM:

事实上, IE 是第一个原生支持 XML 的浏览器,而这一支持是通过 ActiveX 对象实现的。为了便于桌面应用程序开发人员处理 XML,微软创建了 MSXML 库;但微软并没有针对 JavaScript 创建不同的对象,而只是让 Web 开发人员能够通过浏览器访问相同的对象。要创建一个 XML 文档的实例,也要使用 ActiveXObject 构造函数并为其传入一个表示XML 文档版本的字符串。有 6 种不同的 XML 文档版本可以供选择。
 Microsoft.XmlDom:最初随同 IE 发布;不建议使用。
 MSXML2.DOMDocument:为方便脚本处理而更新的版本,建议仅在特殊情况下作为后备版本使用。
 MSXML2.DOMDocument.3.0:为了在 JavaScript 中使用,这是最低的建议版本。
 MSXML2.DOMDocument.4.0:在通过脚本处理时并不可靠,使用这个版本可能导致安全警告。
 MSXML2.DOMDocument.5.0:在通过脚本处理时并不可靠,使用这个版本同样可能导致安全警告。
 MSXML2.DOMDocument.6.0:通过脚本能够可靠处理的最新版本。

通过尝试创建每个版本的实例并观察是否有错误发生,可以确定哪个版本可用。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
<title>JavaScript 与 XML</title>
<script type="text/javascript">
window.onload=function(){
    function createDocument(){
        if(typeof arguments.callee.activeXString !="string"){
            var versions=["MSXML2.DOMDocument.6.0", "MSXML2.DOMDocument.3.0","MSXML2.DOMDocument"]
            ,i
            ,len;
            for(i=0,len=versions.length;i<len;i++){
                try{
                    new  ActiveXObject(versions[i]);
                    arguments.callee.activeXString=versions[i];
                    break;
                }catch(ex){

                }
            }
        }
        return new ActiveXObject(arguments.callee.activeXString);
    };
    var xmldom=createDocument();
    xmldom.async=false;
    xmldom.load("web.xml");
    if(xmldom.parseError !=0){
        //处理错误
    }else{
        alert('1');
    }
};
</script>
</head>
<body>
</body>
</html>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
<title>JavaScript 与 XML</title>
<script type="text/javascript">
window.onload=function(){
    function parseXml(xml){
        var xmldom = null;
        if (typeof DOMParser != "undefined"){
            xmldom = (new DOMParser()).parseFromString(xml, "text/xml");
            var errors = xmldom.getElementsByTagName("parsererror");
            if (errors.length){
                throw new Error("XML parsing error:" + errors[0].textContent);
            }
        } else if (typeof ActiveXObject != "undefined"){
            xmldom = createDocument();
            xmldom.loadXML(xml);
            if (xmldom.parseError != 0){
                throw new Error("XML parsing error: " + xmldom.parseError.reason);
            }
        } else {
            throw new Error("No XML parser available.");
        }
        return xmldom;
    }
};
</script>
</head>
<body>
</body>
</html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值