Angular 8 jsonp的回调函数未被调用。
创始人
2024-10-17 14:30:14
0

在Angular 8中,使用Jsonp进行跨域请求时,可能会遇到回调函数未被调用的问题。以下是一个解决方法的代码示例:

首先,确保你的Angular项目已经安装了jsonp模块。你可以通过运行以下命令来安装该模块:

npm install @angular/http

接下来,你需要在你的组件中导入相应的模块:

import { Component, OnInit } from '@angular/core';
import { Jsonp, URLSearchParams } from '@angular/http';
import { Observable } from 'rxjs/Observable';
import 'rxjs/add/operator/map';

@Component({
  selector: 'app-example',
  template: `
    
  `
})
export class ExampleComponent implements OnInit {
  constructor(private jsonp: Jsonp) {}

  ngOnInit() {}

  getData() {
    let search = new URLSearchParams();
    search.set('callback', 'JSONP_CALLBACK');

    this.jsonp
      .get('http://example.com/api/data', { search })
      .map(response => response.json())
      .subscribe(
        data => {
          // 处理返回的数据
          console.log(data);
        },
        error => {
          // 处理错误
          console.error(error);
        }
      );
  }
}

在上述示例中,我们首先导入了Jsonp和URLSearchParams模块,它们分别用于发起Jsonp请求和设置请求参数。然后,在getData函数中,我们创建了一个URLSearchParams对象,并设置了回调函数的名称为'JSONP_CALLBACK'。接下来,我们使用Jsonp的get方法发起了一个Jsonp请求,并通过map操作符将响应转换为JSON格式。最后,我们通过subscribe方法来订阅这个Observable对象,并在回调函数中处理返回的数据或错误。

请注意,这只是一个示例,你还需要根据你的具体需求进行相应的修改。另外,确保你的服务器端已经正确地配置了跨域访问的相关头部信息,否则你可能仍然会遇到跨域请求被阻止的问题。

相关内容

热门资讯

两分钟辅助!开心泉州小程序开挂... 两分钟辅助!开心泉州小程序开挂有什么技巧,原来真的是有辅助插件(有挂教学)开心泉州小程序开挂有什么技...
七分钟辅助!奇迹脚本辅助,真是... 七分钟辅助!奇迹脚本辅助,真是有辅助软件(确实有挂)1、超多福利:超高返利,海量正版游戏,奇迹脚本辅...
一分钟辅助!天天贵阳智能辅助器... 一分钟辅助!天天贵阳智能辅助器,原来是有辅助脚本(真的有挂)亲,关键说明,天天贵阳智能辅助器透视脚本...
3分钟辅助!一起宁德钓蟹黑科技... 3分钟辅助!一起宁德钓蟹黑科技辅助软件推荐,其实真的有辅助挂(有挂存在)1、玩家可以在一起宁德钓蟹黑...
第二分钟辅助!大菠萝789辅助... 第二分钟辅助!大菠萝789辅助器下载,原来存在有辅助挂(存在有挂)运大菠萝789辅助器下载辅助工具,...
3分钟辅助!科乐填坑辅助,原来... 3分钟辅助!科乐填坑辅助,原来真的是有辅助器(有挂方略)1、下载好科乐填坑辅助透视辅助下载之后点击打...
3分钟辅助!潮友会透视辅助教程... 3分钟辅助!潮友会透视辅助教程,果然存在有辅助器(有挂辅助)亲,关键说明,潮友会透视辅助教程透视脚本...
4分钟辅助!福建兄弟十三冰修改... 4分钟辅助!福建兄弟十三冰修改器,本来真的是有辅助app(有挂讲解)1、游戏颠覆性的策略玩法,独创攻...
第二分钟辅助!wepoker插... 第二分钟辅助!wepoker插件程序,真是是真的有辅助技巧(有挂细节)1、不需要AI权限,帮助你快速...
1分钟辅助!悠悠互娱辅助,真是... 1分钟辅助!悠悠互娱辅助,真是是有辅助神器(有挂解密)悠悠互娱辅助透视方法中分为三种模型:悠悠互娱辅...