原生JavaScript实现跨域

时间:2022-08-28 17:24:36
为什么需要跨域呢?这是因为我们一般的请求都是使用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>