js 以 ajax 的方式导入 XML 或其他文件

本文介绍了一种使用JavaScript从不同浏览器加载XML文件的通用方法,并详细解释了如何处理各种浏览器之间的兼容性问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  开始学习 js 的时候与很多新手一样,都会做类似‘二级联动’之类的小 demo,这时会有需要用 js 导入 XML 或者 JSON 之类文件的情况,但是,js 导入这些文件却不是一件简单的事,问题在于不同浏览器间的兼容!这里有三种浏览器被需要分别兼容,分别是:
- 1、IE浏览器(new ActiveXObject(‘Microsoft.XMLDOM’);)
- 2、谷歌、360浏览器等(使用同步 ajax)
- 3、火狐、Opera、Safari等(document.implementation.createDocument(“”, “”, null);)
可见比较方便的方法是直接都使用同步 ajax。
接下来直接上代码:

    var parseXml = function(fileName) {
        var xmlDoc = null;
        var xmlhttp =null;
        try{
            xmlhttp = new window.XMLHttpRequest(); //Chrome、Firefox、Opera、Safari 等,貌似IE7及其以上的版本也是用这种方式了。
            xmlhttp.open("GET", fileName, false);
            xmlhttp.send(null);
            xmlDoc = xmlhttp.responseXML.documentElement;
        }catch(e){
            try{
                xmlhttp = new ActiveXObject("Msxml2.XMLHTTP"); //较高版本IE
                xmlhttp.open("GET", fileName, false);
                xmlhttp.send(null);
                xmlDoc = xmlhttp.responseXML.documentElement;
            }catch(e){
                try{
                    xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); //较低版本IE
                    xmlhttp.open("GET", fileName, false);
                    xmlhttp.send(null);
                    xmlDoc = xmlhttp.responseXML.documentElement;
                }catch(e){
                    alert("用的什么二狗子浏览器!");
                }
            }
        }
        return xmlDoc;
    }

by the way,IE浏览器有时候会出现以下异常:
    XMLHttpRequest: 网络错误 0x2f78, 由于出现错误 00002f78 而导致此项操作无法继续
具体原因以及出现场景戳这里

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值