微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

JSONP扫盲篇

参考资料

JSONP的起源

  1. 普通的Ajax请求不能跨域
  2. Web上拥有src属性标签(例如<script>、<img>、<iframe>)拥有跨域的能力
  3. 想要通过Web端跨域访问数据,就需要在服务端设法把数据装进js文件,然后让Web端去调用
  4. 刚好JSON格式流行起来了,而且原声JS支持JSON格式
  5. Web端请求服务器上动态生成的JS文件,来解决Web端跨域请求的问题
  6. 慢慢就形成了一种非正式协议,叫做JSONP。

什么是JSONP

  • JSONP(JSONP - JSON with Padding)

JSONP的前端实现方式

  • 本人太懒,此处套用一下阮老师的代码
<script>
function addScriptTag(src) {
  var script = document.createElement('script');
  script.setAttribute("type","text/javascript");
  script.src = src;
  document.body.appendChild(script);
}

window.onload = function () {
  addScriptTag('http://example.com/ip?callback=foo');
}

function foo(data) {
  console.log('Your public IP address is: ' + data.ip);
};
</script>
  • 不得不提的jQuery中的实现方式
    • jQuery在处理JSONP类型的请求时,自动帮你生成回调函数并把数据取出来供success属性方法调用
    • 在jQuery中,使用JSONP感觉就和使用Ajax没有区别,但实际上它们的底层实现实现是完全不一样的。
    • 通常都会把JSONP封装到了ajax中,但是JSONP不是Ajax的一个特例。

需要后台支持什么

  • 当使用script请求地址时,会将返回的字符串,认当成js解析。由于后端返回是的callback(xxx),所以会调用本地的callback函数

  • 从原理上来看,要使用JSONP,必须要后端返回相应的数据,这个就是JSONP的模式了,允许客户端传递一个callback函数,后端将数据包裹在callback函数中返回。

容易混淆的概念之xhr

  • XMLHttpRequest 用于在后台与服务器交换数据,是Ajax的基础。
  • 可以在不重新加载整个网页的情况下,对网页的某部分进行更新。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


AJAX是一种基于JavaScript和XML的技术,能够使网页实现异步交互,节省带宽和时间,提高用户体验。在使用AJAX时,需要通过解析JSON格式的数据,来获取所需要的数据。
在网页开发中,我们常常需要通过Ajax从后端获取数据并在页面中展示出来。其中,JSON是一种常用的数据格式。那么,在使用Ajax获取JSON数据后,如何将数据取出来呢?
在前端开发中,经常需要循环JSON对象数组进行数据操作。使用AJAX技术可以在不刷新页面的情况下异步获取数据。那么我们该如何循环JSON对象数组呢?下面我们通过一段代码来进行讲解。
AJAX(Asynchronous JavaScript and XML)是一种用于创建 Web 应用程序的技术,它使用 JavaScript 和 XML(或 JSON)来在后台异步传输数据。
AJAX技术被广泛应用于现代Web开发,它可以在无需重新加载页面的情况下,向服务器发出请求并更新页面,实现了异步更新的效果。而传递JSON数据是AJAX中比较常见的一种方法,下面是如何使用AJAX传递JSON数据的详细介绍。
Ajax是一种通过JavaScript和HTTP请求交互的技术,可以实现无需刷新页面的异步数据交互。在处理数据时,常常需要删除一些已存在的数据。本文将介绍如何使用Ajax删除JSON数据库中的数据。
在使用Ajax时,我们经常需要将数据格式化为JSON格式。JSON是一种轻量级数据交换格式,它以键值对的形式来表达数据。
AJAX是一种支持异步请求的技术,它可以让前端页面不用刷新就能向后台请求数据,并异步地展示给用户,提高了用户的体验感。其中,使用JSON格式化数据可以帮助我们更方便快捷地处理返回的数据。
AJAX是一种前端技术,可以通过异步请求来获取数据,并在页面上更新它们。JSON是一种轻量级的数据交换格式,因为它易于读取和编写,因此在Web应用程序中被广泛使用。AJAX传送JSON数据是一种常见的技术,可以让Web应用
在前端开发中,ajax是很常见的技术,它可以在不刷新整个页面的情况下请求服务器数据和更新部分页面。而当需要遍历多个json文件时,可以使用ajax循环遍历来实现。