JavaScript中模拟实现jsonp

JavaScript中模拟实现jsonp,需要遵循以下步骤:

1. 创建一个script标签

在DOM中创建一个script标签,并设置其src属性为需要跨域请求的URL,同时还需要设置一个callback参数,作为后端接口返回数据的回调函数名。

const script = document.createElement('script');
script.src = 'http://example.com/data?callback=getData';
document.body.appendChild(script);

2. 定义回调函数

定义一个全局函数,函数名与callback参数的值相同,该函数用于接收后端返回的数据,并处理它。在处理结束之后,可以根据需要将数据传递给其他函数进行展示或其他操作。

function getData(data) {
  // 处理数据
  console.log(data);
}

3. 后端返回数据

后端需要根据callback参数的值,在返回的数据中调用该函数,并传入需要返回的数据,此时会自动执行callback函数的代码。需要注意返回的数据格式为JS代码。

getData({
  name: '张三',
  age: 18,
  gender: '男'
});

示例1

例如,我们需要请求豆瓣电影API,获取热映电影的数据,并展示在页面上。首先,我们创建一个script标签,定义好回调函数,并通过callback参数传递给后端:

const script = document.createElement('script');
script.src = 'https://api.douban.com/v2/movie/in_theaters?callback=handleData';
document.body.appendChild(script);

function handleData(data) {
  console.log(data);
}

然后,后端根据callback参数调用该函数,并将数据格式化为JS代码后返回给前端:

handleData({
  "count": 20,
  "start": 0,
  "total": 39,
  "subjects": [
    {
      "rating": {
        "max": 10,
        "average": 7.4,
        "stars": "40",
        "min": 0
      },
      "genres": [
        "动作",
        "科幻"
      ],
      "title": "蜘蛛侠:英雄远征",
      "casts": [
        {
          "avatars": {
            "small": "https://img3.doubanio.com/view/celebrity/s_ratio_celebrity/public/p1360451470.99.webp",
            "large": "https://img3.doubanio.com/view/celebrity/s_ratio_celebrity/public/p1360451470.99.webp",
            "medium": "https://img3.doubanio.com/view/celebrity/s_ratio_celebrity/public/p1360451470.99.webp"
          },
          "name_en": "Tom Holland",
          "name": "汤姆·赫兰德",
          "alt": "https://movie.douban.com/celebrity/1339225/",
          "id": "1339225"
        },
        {
          "avatars": {
            "small": "https://img3.doubanio.com/view/celebrity/s_ratio_celebrity/public/p1507059488.68.webp",
            "large": "https://img3.doubanio.com/view/celebrity/s_ratio_celebrity/public/p1507059488.68.webp",
            "medium": "https://img3.doubanio.com/view/celebrity/s_ratio_celebrity/public/p1507059488.68.webp"
          },
          "name_en": "Zendaya",
          "name": "赞达亚",
          "alt": "https://movie.douban.com/celebrity/1378051/",
          "id": "1378051"
        }
      ],
      "collect_count": 151249,
      "original_title": "Spider-Man: Far from Home",
      "subtype": "movie",
      "directors": [
        {
          "avatars": {
            "small": "https://img1.doubanio.com/view/celebrity/s_ratio_celebrity/public/p1433934340.49.webp",
            "large": "https://img1.doubanio.com/view/celebrity/s_ratio_celebrity/public/p1433934340.49.webp",
            "medium": "https://img1.doubanio.com/view/celebrity/s_ratio_celebrity/public/p1433934340.49.webp"
          },
          "name_en": "Jon Watts",
          "name": "乔恩·沃茨",
          "alt": "https://movie.douban.com/celebrity/1330053/",
          "id": "1330053"
        }
      ],
      "year": "2019",
      "images": {
        "small": "https://img3.doubanio.com/view/photo/s_ratio_poster/public/p2558261313.webp",
        "large": "https://img3.doubanio.com/view/photo/s_ratio_poster/public/p2558261313.webp",
        "medium": "https://img3.doubanio.com/view/photo/s_ratio_poster/public/p2558261313.webp"
      },
      "alt": "https://movie.douban.com/subject/27032767/",
      "id": "27032767"
    },
    ...
  ],
  "title": "正在上映的电影-北京"
});

最后,在处理数据的函数中,我们可以根据需要将数据展示在页面上。

示例2

在一些极端情况下,由于后端不支持返回callback函数,或者返回的数据不规范,这时候需要手动写一个callback函数来处理。

例如,我们需要请求某个站点的数据,该站点不支持jsonp调用,只能通过Ajax跨域请求,但是这个网站的CORS规则没有设置,无法进行跨域请求。这时候,我们可以手动声明一个全局函数,在请求数据之前,先通过script标签把该函数注入到页面中,请求数据返回之后,再通过该函数进行处理。

window.handleData = function(data) {
  console.log(data);
}

const script = document.createElement('script');
script.innerHTML = `handleData({name: 'abc'})`;
document.body.appendChild(script);

这里需要声明一个全局的handleData函数,并将其注入到页面中。创建一个script标签,同时将注入的代码也放到script标签内部。这样,就可以在请求数据返回之后,通过该全局函数进行数据的处理和展示。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:JavaScript中模拟实现jsonp - Python技术站

(1)
上一篇 2023年5月27日
下一篇 2023年5月27日

相关文章

  • JS面向对象(3)之Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法

    JS面向对象(3)之Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法 JS作为一门基于面向对象的语言,其语法中包含了许多与对象有关的特性。本文将介绍JS中Object类、静态属性、闭包、私有属性、call和apply的使用、继承的三种实现方法。 Object类 在JS中,所有对象都是由Object类派生而来,因此也可…

    JavaScript 2023年5月27日
    00
  • JS数组方法push()、pop()用法实例分析

    JS数组方法push()、pop()用法实例分析 push()方法 push() 方法将一个或多个元素添加到数组的末尾,并返回新数组的长度。 语法 arr.push(element1[, …[, elementN]]) 参数 element1[, …[, elementN]]: 要添加到数组末尾的一个或多个元素。 返回值 数组新的长度 示例 cons…

    JavaScript 2023年5月28日
    00
  • vue element-ui使用required进行表单校验时自定义提示语问题

    在Vue中使用Element-UI进行表单校验时,可以使用required属性来进行必填校验。然而,在默认情况下,当该表单项未填写时,Element-UI会输出“该字段不能为空”的默认提示语,而有时候我们希望自定义提示语。下面是自定义提示语的攻略: 使用label属性自定义提示语 如果我们不想使用默认提示语,可以使用label属性来自定义提示语。在使用lab…

    JavaScript 2023年6月10日
    00
  • 有趣的JavaScript数组长度问题代码说明

    下面我会详细讲解“有趣的JavaScript数组长度问题代码说明”的完整攻略,包含以下内容: 核心概念:JavaScript数组的length属性 思路分析:通过操作length属性实现数组元素的删除与插入 代码示例1:删除数组元素的常规方法和length属性的应用 代码示例2:插入数组元素的常规方法和length属性的应用 1. 核心概念:JavaScri…

    JavaScript 2023年5月27日
    00
  • JavaScript包装对象使用详解

    JavaScript包装对象使用详解 在JavaScript中,有三种基本数据类型:字符串、数字和布尔值。但是在实际开发中,我们通常需要使用更复杂的数据类型,这时就需要使用JavaScript的包装对象。 什么是JavaScript包装对象 JavaScript提供了三种基本类型的包装对象:String、Number和Boolean。当我们在基本类型上调用一…

    JavaScript 2023年5月27日
    00
  • Three.js 进阶之旅:全景漫游-高阶版在线看房 ?

    声明:本文涉及图文和模型素材仅用于个人学习、研究和欣赏,请勿二次修改、非法传播、转载、出版、商用、及进行其他获利行为。 摘要 专栏上篇文章《Three.js 进阶之旅:全景漫游-初阶移动相机版》中通过创建多个球体全景场景并移动相机和控制器的方式实现了多个场景之间的穿梭漫游。这种方式的缺点也是显而易见的,随着全景场景的增加来创建对应数量的球体,使得空间关系计算…

    JavaScript 2023年4月17日
    00
  • Javascript Date setUTCMonth() 方法

    以下是关于JavaScript Date对象的setUTCMonth()方法的完整攻略,包括两个示例说明。 JavaScript Date对象的setUTCMonth()方法 JavaScript的setUTCMonth()方法设置对象UTC月份部分。方法接受一个整数,表示要设置的UTC月份如果该参数超出了JavaScript所能表示的范围,则自动调整为相应…

    JavaScript 2023年5月11日
    00
  • JavaScript阻止事件冒泡的方法

    JavaScript中阻止事件冒泡是前端开发过程中常见的需求。事件冒泡是指当一个元素上的事件被触发时,它会向父级元素传递,直到最顶层的元素。在某些情况下,我们需要阻止这种事件冒泡,使事件只在当前元素上执行。以下是阻止事件冒泡的三种方法: 方法一:使用event.stopPropagation 在事件回调函数中使用event.stopPropagation可以…

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