jQuery.Ajax IE8,9 无效(CORS跨域)

时间:2021-06-08 18:59:01

今天在开发网站的时候,发现一个问题,$.ajax()在 IE8,9 浏览器不起作用,但 Chrome,Firefox ,360,IE10以上等浏览器却是可以的,网上资料很多,查询最后发现是 IE8,9 默认不支持 CORS 请求,需要手动开启下 代码如下:

jQuery.support.cors = true;   //写在$.ajax()前面

用户这样设置:点击IE浏览器的的“工具->Internet 选项->安全->自定义级别”将“其他”选项中的“通过域访问数据源”选中为“启用”或者“提示”,点击确定IE8,9就获取到数据了

但是不可能每个用户都这样设置,这样太过麻烦,此方法不友好!

最后网上查询到一个插件可以解决此问题:跨域方式的插件jquery.xdomainrequest.min.js,将此插件引入到HTML页面中即可

完整代码示范如下:

<!DOCTYPE html>
<html>
   <head>
    <meta charset="UTF-8">
    <title>jQuery.Ajax IE8,9跨域</title>
    <script src="jquery-1.11.1.min.js"></script>
    <script src="jquery.xdomainrequest.min.js"></script>
   </head>
    <body>
	<script>
	jQuery.support.cors = true; 
//$ajax({}) 正常写 $.ajax({ type : "GET", dataType : "JSON", url : "url", success: function(data){ //执行事件 }, error:function(){ alert("错误"); } }); </script> </body> </html>

jquery.xdomainrequest.min.js 插件github上搜索:jQuery-ajaxTransport-XDomainRequest 可以下载