欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

使用jsonp实现跨域获取数据实例讲解

程序员文章站 2022-05-03 22:45:56
js部分 (function(window, document) { 'use strict'; var jsonp = function(url,...

js部分

(function(window, document) {
  'use strict';
  var jsonp = function(url, data, callback) {
    //1、挂载回调函数
    var fnsuffix = math.random().tostring().replace('.', '');
    var cbfuncname = 'my_json_cb' + fnsuffix;
    window[cbfuncname] = callback;
    //2、将data转换成url字符串的形式
    //{id=1,count=4}==>id=1&count=4
    var querystring = url.indexof('?') == -1 ? '?' : '&';   //判断url中最后是否有?,没有则为?
    for (var key in data) {
      querystring += key + '=' + data[key] + '&';
    }
    //3、处理url中回调函数 url+=callback=sdgade
    querystring += 'callback=' + cbfuncname;
    //querystring=?id=1&count=4&callback=sdgade
    //4、创建一个script标签
    var scriptelement = document.createelement('script');
    scriptelement.src = url + querystring;
    //5、把script标签放到页面上
    document.body.appendchild(scriptelement);
  };
  window.$jsonp = jsonp;
})(window, document)

在页面中测试

<!doctype html>
<html>
<head>
  <title>jsonp</title>
</head>
<body>
  <div id="htt"></div>
  <script type="text/javascript" src="http.js"></script>
  <script>
    (function(){
      $jsonp('http://api.douban.com/v2/movie/in_theaters',{},  
        function(data){
          document.getelementbyid('htt').innerhtml=json.stringify(data);
        });
    })()
  </script>
</body>
</html>

结果可以返回结果,页面显示为,表示获取成功!

以上所述是小编给大家介绍的使用jsonp实现跨域获取数据实例讲解,希望对大家有所帮助