有一种朋友不在生活里,却在生命力;有一种陪伴不在身边,却在心间。图老师即在大家的生活中又在身边。这么贴心的服务你感受到了吗?话不多说下面就和大家分享解决ajax跨域问题的实例吧。
【 tulaoshi.com - Web开发 】
要解决ajax跨域问题,网上给出的方法有二:
1是构建服务器端的代理。简而言之,就是ajax中调用的实质还是本机的url,而服务器端替js去取回远端地址。
2.利用script标记,生成一个标签。在js加载完成后,再执行后续操作。
就是将原来新建xmlHTTPrequest对象的操作改成了新建script标签的操作.
这里给出一个例子:
#ajah.js
var  Ajah=function(url,varname,handleSuccess,handleFailure){ 
        /** 
        * handleSuccess,handleFailure must be functions 
        * */ 
        script = document.createElement("script"); 
        script.src=url; 
        var handler = function(str) 
        { 
                handleSuccess(str); 
        } 
        script.onload = function() 
        { 
                var json=eval(varname); 
                handler(json); 
        } 
        if(window.ie) 
        { 
                script.onreadystatechange = function() 
                { 
                        if(script.readyState=='complete'||script.readyState== 'loaded') 
                        { 
                                var json=eval(varname); 
                                if(typeof json != 'undefined') 
                                { 
                                        handler(json); 
                                } 
                        } 
                } 
        } 
        document.body.appendChild(script); 
}
而在网页中应这样调用:
#demo.html
(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)pre 
!DOCTYPE html PUBLIC "-//W3C//DTD HTML 3.2//EN" 
html 
head 
  meta name="generator" content= 
  "HTML Tidy for Linux (vers 1 September 2005), see www.w3.org" 
  
  title/title 
        script src="mootools.js"/script 
        script src="ajah.js"/script 
/head 
  
body 
script 
var ajah=new Ajah("data.js","json198",function(str){ 
        console.debug("returned:"); 
        console.debug(str); 
}, 
function(str){}); 
/script 
/body 
/html 
/pre
被调用的数据文件如下
#data.js
(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)var json198="hello,this is json198";
funciton Ajah(url,varname,handleSuccess,handleFailure){}
Ajah这个构造函数调用四个参数:
url:远端地址
varname:远端返回数据的变量名
handleSuccess:加载完毕后加载的函数
handleFailure:暂时没用上
来源:http://www.tulaoshi.com/n/20160220/1632336.html
看过《解决ajax跨域问题的实例》的人还看了以下文章 更多>>