什么是jsonp

jsonp 是前端一种用来解决网站跨域的技术,利用script标签不受同源策略影响的特性引入一个非同源的js文件,并定义一个回调函数来接收数据,这样就可以实现跨域获取数据了,例如:
现在有一个链接返回的数据是这样的:

cb({
    "name": "swk",
    "age": 18
})

这是一个标准的jsonp格式,它通过调用函数cb来传递数据,那么我们只需要定义一个函数cb来接收数据就可以了,例如:

function cb(data) {
    console.log(data); //{ name: "swk", age: 18 }
}

那么我们只需要在页面中引入这个js文件就可以了,例如:

<script src="xxx.xxx?callback=cb"></script>

这样就可以实现跨域获取数据了,但是这种方式有一个缺点,就是只能通过get方式来传递数据,例如:

<script src="xxx.xxx?callback=cb&name=swk&age=18"></script>

这样就可以传递数据了,但是如果数据量比较大的话,那么就会有问题,因为get方式传递的数据是有长度限制的,所以这种方式只适合传递少量的数据,如果数据量比较大的话,那么就需要使用ajax的jsonp的方式来传递数据了,例如:

$.ajax({
    url: 'xxx.xxx',
    dataType: 'jsonp',
    jsonp: 'callback',
    data: {
        name: 'swk',
        age: 18
    },
    success: function (data) {
        console.log(data);
    }
})
jsonp的格式

一般情况下jsonp的内容是这样的:

callback({
    "name":"zhangsan",
    "age":18
})

也有有可能是这样的:

callback(
    'name',
    (function(a,b,c){
        return {
            name:a,
            age:b,
            gender:c
        }
    })('孙悟空',18,'男')
)

原文链接:https://www.cnblogs.com/primice/p/17384564.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:什么是jsonp - Python技术站

(0)
上一篇 2023年5月9日
下一篇 2023年5月9日

相关文章

  • JS猜数字游戏实例讲解

    JS猜数字游戏实例讲解 猜数字游戏是一种基于逻辑和推理的有趣互动游戏。下面将通过一个JS猜数字游戏实例来讲解如何实现这个游戏。 游戏规则 猜数字游戏的规则非常简单:系统会自动随机生成一个数,在限定的次数内,玩家需要通过猜测数字来确定该数,如果玩家猜中了,游戏结束,玩家胜利;反之,如果玩家未在限定的次数内猜出该数,则游戏失败。 实现步骤 随机生成目标数字:使用…

    JavaScript 2023年6月10日
    00
  • JS基于正则实现数字千分位用逗号分隔的方法

    下面是JS基于正则实现数字千分位用逗号分隔的方法的完整攻略。 什么是数字千分位? 在很多情况下,我们需要将数字的千位用逗号分隔,比如说 1000,我们需要显示为 1,000,这样更易于辨认和阅读。 实现方法 在 JavaScript 中,可以使用正则表达式来实现数字千分位的处理。以下是具体实现步骤: 步骤一:将数字转换为字符串 首先,我们要将需要处理的数字转…

    JavaScript 2023年5月28日
    00
  • JavaScript编写推箱子游戏

    下面是JavaScript编写推箱子游戏的完整攻略: 1. 准备工作 编写推箱子游戏前需要准备的工作如下: 确认游戏规则和界面设计; 编写HTML页面,并引入所需的CSS样式; 编写JavaScript脚本文件,并在HTML中引入。 2. 游戏规则 推箱子游戏是一种益智类的游戏,玩家需要将箱子移动到指定位置才能完成游戏。游戏规则如下: 游戏地图上有多个目的地…

    JavaScript 2023年6月11日
    00
  • Javascript Date getTime() 方法

    以下是关于JavaScript Date对象的getTime()方法的完整攻略,包括两个示例说明。 JavaScript Date对象的getTime()方法 JavaScript Date对象的getTime()方法返回自1970年1月1日00:00:00 UTC以来的毫秒数。这个毫秒数可以用于比较日期和时间,或者用于计算时间间隔。 下面是使用Date对象…

    JavaScript 2023年5月11日
    00
  • js显示世界时间示例(包括世界各大城市)

    下面就是“js显示世界时间示例(包括世界各大城市)”的完整攻略。 思路概述 本代码的主要思路是通过获取当前时间(即本地时间),将其转换为世界各大城市的对应时间,并在页面上显示出来。具体实现方法是使用 JavaScript 和 Moment.js 库。 实现步骤 引入 Moment.js 库 Moment.js 是一个 JavaScript 日期处理库,可以方…

    JavaScript 2023年5月27日
    00
  • javascript实现一个网页加载进度loading

    下面是关于Javascript实现一个网页加载进度loading的完整攻略。 步骤一:添加HTML结构 首先,在网页的HTML结构中添加loading元素,用于显示进度条和加载状态。可以采用下面代码模板: <div id="loading"> <div id="progress"></di…

    JavaScript 2023年6月11日
    00
  • webpack常用配置总览(小结)

    下面是针对“webpack常用配置总览(小结)”的完整攻略: webpack常用配置总览(小结) 简介 Webpack 是一个前端资源加载/打包工具。它将前端资源文件(如 JavaScript,CSS,图片等)视为模块,通过 Webpack 的插件机制实现对这些模块的管理、依赖分析、打包等功能。 本文将总结一些 Webpack 的常用配置选项,供大家参考。本…

    JavaScript 2023年6月10日
    00
  • js中延迟加载和预加载的具体使用

    下面我将详细讲解JS中延迟加载和预加载的使用攻略。 一、什么是延迟加载和预加载 1. 延迟加载 延迟加载(Lazy Load)是指在页面加载完成后,对于一些非必要的资源如图片、视频等等,先不进行加载,待页面滚动或者用户发生某些操作时再加载。这样可以让页面加载更快,提高用户的体验感。 2. 预加载 预加载(Preload)是指在页面正式加载之前,将一些可能需要…

    JavaScript 2023年5月27日
    00
合作推广
合作推广
分享本页
返回顶部