Zan*_*r17 73 http typescript tslint angular
我目前对tslint有一个问题,希望有人能指出我正确的方向.
我正在尝试使用Angular2框架提供的HTTP发送HTTP GET请求.有了这个请求,我必须指定内容类型和承载认证令牌.
我的代码示例:
let headers = new Headers();
let authToken = this._user.getUser().JWT;
headers.append('Content-Type', 'application/json');
headers.append('Authorization', `Bearer ${authToken}`);
let options = new RequestOptions({ headers: headers });
this._http.get('http://' + url '/', options)
.timeout(3000)
.subscribe(
(res) => {
Run Code Online (Sandbox Code Playgroud)
然而,这是有效的,tslint抱怨说
"TS2345:类型'{headers:Headers;}'的参数不能分配给'RequestOptionsArgs'类型的参数.属性'headers'的类型是不兼容的.类型'Headers'不能分配给'Headers'类型.两种不同的类型存在此名称,但它们不相关."标题"类型中缺少属性"键".
我很感谢这种支持.
bvi*_*ale 201
更新
截至今天,@angular/http已被弃用,@angular/common/http应该改为使用.因此,使用http标头的最佳方法是导入import { HttpHeaders } from '@angular/common/http';(文档).
老答案
Headers您应该导入的类型是import { Headers } from '@angular/http';.
检查你的进口
小智 8
您必须通过以下方式更新标头:
let headers = {headers: new HttpHeaders({ 'Content-Type': 'application/x-www-form-urlencoded'})};
Run Code Online (Sandbox Code Playgroud)
Angular 5的更新
import { RequestOptions } from '@angular/http';
Run Code Online (Sandbox Code Playgroud)
我在正确答案的评论中找到了这个,所以如果这有助于某人,祝你好运.
文档:https://angular.io/api/http/RequestOptions
| 归档时间: |
|
| 查看次数: |
68646 次 |
| 最近记录: |