关于jquery的$ajax不兼容ie的问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于jquery的$ajax不兼容ie的问题相关的知识,希望对你有一定的参考价值。

 在做项目的过程中,经常碰到ie的不兼容问题,目前大部分问题主要集中在ie8、ie9这两款浏览器上。
     最近碰到的问题就是jquery的$.ajax方法不兼容ie9的问题。网上的方法是用jsonp或者cors跨域的方法来解决。
    首先 jsonp只能使用get请求,无法使用post请求,而cors跨域也只能解决部分问题。我尝试了几种方法都不行。最后使用XDomainRequest解决了问题。代码中应当引入   :
    <script src="js/jquery-1.9.1.min.js"></script>
    <script src="js/jquery.xdomainrequest.min.js"></script>
xdomainrequest这个js文件可以从github上下载。下载地址:
    https://github.com/MoonScript/jQuery-ajaxTransport-XDomainRequest
    还有一个问题,引入之后,
        $.ajax({
    type: ‘post‘,
    url: pubUrl + ‘/menu/0‘,
    dataType: ‘json‘,
    async: true,
    success: function(data){
        $.each(data,function(i,v){
            var html = ‘<li><a href="‘+v.url+‘" id="‘+v.id+‘">‘+v.name+‘</a></li>‘;
            $(‘.nav-list ul‘).append(html)
        })
    },
    error: function(err){
        console.log(err)
    }
});
async要改成异步true,而不是同步,否则还是无法显示。

以上是关于关于jquery的$ajax不兼容ie的问题的主要内容,如果未能解决你的问题,请参考以下文章

关于jQuery框架的ajax插件

jquery ajax不支持ie6吗

console在ie下不兼容的问题(console在ie9下阻碍页面的加载,打开页面一片空白)

关于jquery版本与兼容ie7,ie8的一些问题

IE8 环境的 JQuery 中的 $.ajax 拒绝访问---解决方案

关于既定技术栈的IE8浏览器兼容