http - 使用 HTTP Angular

标签 http angular

我正在尝试使用 Angular 发出一个简单的 HTTP 请求,但我一直收到此错误:

Property 'http' does not exist on type 'WorksService'.

import {Injectable}     from 'angular2/core';
import {Http, HTTP_PROVIDERS, Response} from 'angular2/http';
import {Observable}     from 'rxjs/Observable';

export class Work {

  constructor(public id: number, public name: string) { }

}


@Injectable()
export class WorksService {

 constructor (private http: Http) {}

 private _WorksUrl = 'api/projects';  // URL to web api

 getHeroes () {
  return this.http.get(this._WorksUrl)
                .map(res => <Work[]> res.json().data)
                .catch(this.handleError);
 }
 private handleError (error: Response) {
   // instead of just logging it to the console
   console.error(error);
   return Observable.throw(error.json().error || 'Server error');
  }
}

最佳答案

我猜你自己实例化了服务。您需要通过依赖注入(inject)来获取它,以便 Angular2 将直接提供 http 实例。

为此,只需在引导应用程序时或在使用该服务(直接或间接)的组件的 providers 属性中添加服务即可。

bootstrap(AppComponent, [ HTTP_PROVIDERS, WorksService ]);

bootstrap(AppComponent, [ HTTP_PROVIDERS ]);

(...)

@Component({
  (...)
  providers: [ WorksService ]
})
export class SomeComponent {}

然后要注入(inject)它,您可以这样做:

@Component({
  (...)
})
export class SomeComponent {
  constructor(private service WorksService) {
    this.service.getHeroes().subscribe(
      (data) => {
        (...)
      });
  }
}

关于http - 使用 HTTP Angular ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36189022/

相关文章:

typescript - Angular 2 - TypeScript : how to hold objects with <Select> control

angular - 弃用警告 : Buffer() is deprecated due to security and usability issues

java - 使用 The Grinder 进行 Web 应用程序性能测试

web-services - 在 golang 中访问 GET 参数 net/http 的问题

angular - 结构指令、位置工具提示

Angular 单元测试 TypeError : this. http.get(...).pipe 不是函数

html - WavPack用于html音频播放

android - QT 和 Android 8.0 : Error creating SSL context () 问题

http - 如何使用 Perl6 与 Github API 交互?

Angular 6私有(private)方法