首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Angular jsonp调用

Angular jsonp调用
EN

Stack Overflow用户
提问于 2017-07-24 14:13:36
回答 1查看 5.7K关注 0票数 3

如何通过新的Angular HttpClientModule进行jsonp调用?

我看到有一个HttpClient.jsonp方法,但是在文档中设置HttpClientJsonpModule拦截器对我来说并不是很清楚。我不确定JsonpCallbackContext应该从哪里来?

https://angular.io/api/common/http/HttpClientJsonpModule

编辑:添加HttpClientJsonpModule会导致以下错误-

代码语言:javascript
复制
Refused to execute script because its MIME type ('application/json') is not executable
EN

回答 1

Stack Overflow用户

发布于 2017-08-30 02:53:24

为了让JSONP在Angular (v4.3+)中工作,您需要在您的AppModule中添加以下代码

代码语言:javascript
复制
import { HttpClientJsonpModule } from '@angular/common/http';
@NgModule({
  imports: [ BrowserModule, HttpClientJsonpModule ],
  bootstrap: [ AppComponent ]
})
export class AppModule { }

然后在您的服务或组件中

代码语言:javascript
复制
private WIKIPEDIA_URL = 'https://en.wikipedia.org/w/api.php';

const url = searchUrl(term, this.WIKIPEDIA_URL);
this.http.jsonp(url, 'callback')

function searchUrl(term, base) {
  let params = new HttpParams()
    .append('action', 'opensearch')
    .append('search', encodeURIComponent(term))
    .append('format', 'json');
  return `${base}?${params.toString()}`;
}

添加了一些维基百科搜索所需的参数。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45273738

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档