有一种朋友不在生活里,却在生命力;有一种陪伴不在身边,却在心间。图老师即在大家的生活中又在身边。这么贴心的服务你感受到了吗?话不多说下面就和大家分享解决ajax跨域问题的实例吧。
【 tulaoshi.com - Web开发 】
要解决ajax跨域问题,网上给出的方法有二:
1是构建服务器端的代理。简而言之,就是ajax中调用的实质还是本机的url,而服务器端替js去取回远端地址。
(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)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
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跨域问题的实例》的人还看了以下文章 更多>>