主题:ajax 跨域取数据
时间: 2020-08-27来源:ITEYE
前景提要
相关推荐: javascript的跨域请求 求XmlHttp 跨域的解决方案 近乎完美的简单 JS 跨域解决方式 --window.name ajax跨域请求WebService.asmx 解决ajax跨域问题【5种解决方案】 原生AJAX请求以及AJAX跨域问题 接口解决跨域问题 ajax 跨域 headers JavaScript ajax 跨域请求 +设置headers 实践 node.js ajax数据请求跨域问题
推荐群组: Jquery
更多相关推荐
JavaScript Ajax
第一次分享。。。 有啥不对的地方。。还望指出! 若有更好的解决方案,呵呵。。 也希望能得到分享!。
      背景: 项目中要显示股票指数数据,由于咱们当前系统中没有这些数据,所以只能通过跨域去取数据。由于指数数据是实时数据,初定方案是通过ajax每隔3秒去指定的地址去拿数据。

var requestObject = {
    url : "地址",
    vars : "参数",
    callBack : 回调函数,
    method : "post",
  };
  var ajax = new TFL.ajax2(); //对XmlHttpRequest 做了封装
  ajax.ajaxRequest(requestObject);
本地测试通过。。。 上测试环境(正式环境)发现不行!。。 才发现ajax无法跨域取数据。(呵呵,web新手。。见笑了)
 第二中方案:
     利用js创建dom的原理,去动态创建一个<script></script>  在指定 scr的值 。
 function c(){
  var date = new Date();
  var hours = date.getHours();
  
  if(hours>=9 && hours <=15){//开盘时间
  a();  }
 }
 
 function a(){
  var head= document.getElementsByTagName('head')[0];
     var script= document.createElement('script');
     script.type= 'text/javascript';
     // 回调只对firefox有效
     script.onreadystatechange= function () {
        if (this.readyState == 'complete') {
            b();
        };
     }
     script.onload= 回调函数;
     // 回调只对firefox有效
     script.src= b;
     head.appendChild(script);
 }
 function b(){//回调函数
 }
 setInterval("c()"3000);
 
上面遗留了一个问题,就是在ie下无法执行回调函数,只能直接去调用函数,但也许会出现这样一种情况,就是数据还在加载,js直接调用回调函数的代码就已经执行了,导致无法取到数据。
  我的解决方案是 :  先判断浏览器,然后在通过定时器去定时执行回调函数。(说白了就是ie下推迟执行回调函数)
// 判断是否ie
  var is_opera = /opera/i.test(navigator.userAgent); 
  var is_ie = (/msie/i.test(navigator.userAgent) && !is_opera)
  if(is_ie){
      setInterval("c()",4000);
  }
     
   以上是我的总结。 。 呵呵   。热烈欢迎踊跃提意见啊。!

科技资讯:

科技学院:

科技百科:

科技书籍:

网站大全:

软件大全:

热门排行