为什么需要跨域呢?这是因为我们一般的请求都是使用xhr的,但是它只能调用同一个域里面的接口,有时候,我们想要在自己的站点中调用其他站点的接口,这时候就要用到跨域了。其实,跨域并不难,我们可以通过JavaScript的动态脚本加载技术来实现。需要注意的是,跨域是需要后台配合的。我们需要约定了一个函数(函数名以参数的形式传到后台),前台使用这个函数进行解析后台返回的数据,而后台需要把返回给前台的数据放到这个函数的参数位置进行调用。下面我们来看一下具体的实现代码:
后台代码如下,为了方便测试, 我已经把它部署到了服务器上了,地址是http://zhangzhanyu.nfreehost.com/jsonp.php
<?php
$callback = $_GET['callback' ];
echo "{$callback}({'msg':'this is a jquery jsonp test message!'})";
?>
前端代码:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>使用JavaScript实现跨域请求</title>
<script type="text/javascript">
var scriptElement = document.createElement("script");
scriptElement.src = "http://zhangzhanyu.nfreehost.com/jsonp.php?callback=callback";
document.head.appendChild(scriptElement); function callback(jsonString) {
//var data = JSON.parse(jsonString);
alert(jsonString.msg);
}
</script>
</head>
<body>
</body>
</html>