jsonp跨域请求豆瓣api封装实例

<script>
    function jsonp(url, arg , fn){
      // 1.动态创建script标签,设置src属性
      var srpt  = document.createElement('script')
      // srpt.src = ''  
      // url?callback=方法名&page=1&cout=10

      // 1.1 拼接url中的参数
      var queryString = ''  // 这个变量保存参数的字符串形式
      for(var key in arg){
          queryString += key + '=' + arg[key] + '&'
      }

      // 不能写死,我们就动态创建方法名
      // 随机生成字符
      var funName = 'fun_'+ Math.random().toString().substr(3) // fun_0.121212

      window[funName] = fn

      url += '?' + queryString

      // 1.2 设置callback参数,并创建方法

      url += 'callback=' + funName

      srpt.src = url
      // 2.把得到的script标签添加到dom上去
      document.body.appendChild(srpt)
    }

    // 使用,url:'',arg:{}, callback
    jsonp('https://api.douban.com/v2/movie/coming_soon',{start:0,count:10},
      function(data){
        console.log(data)
      })

    // 使用,url:'',arg:{}, callback
    jsonp('https://api.douban.com/v2/movie/coming_soon',{start:0,count:20},
      function(data){
        console.log(data)
      })

  </script>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值