j'utilise 2.0 angulaire dans ASP.NET projet et coincé avec erreur d'importation rxjs en composant à utiliser dans this.http.get
/this.http.post
.
Paramètres angulaires:
"@angular/common": "2.0.0-rc.4",
"@angular/compiler": "2.0.0-rc.4",
"@angular/core": "2.0.0-rc.4",
"@angular/forms": "0.2.0",
"@angular/http": "2.0.0-rc.4",
"@angular/platform-browser": "2.0.0-rc.4",
"@angular/platform-browser-dynamic": "2.0.0-rc.4",
"@angular/router": "3.0.0-beta.2",
"@angular/router-deprecated": "2.0.0-rc.2",
"@angular/upgrade": "2.0.0-rc.4",
"rxjs": "5.0.0-beta.6"
Sur le composant:
import "rxjs/add/operator/toPromise";
En fonction, j'essaie d'obtenir des données de http.get
requet et gérer la réponse avec toPromise
:
getData(): Promise<IToDo[]> {
return this.http.get("app/shared/todos.json")
.toPromise() // <- ERROR
.then(res => res.json())
.catch(this.handleError);
}
private handleError(error: any): Promise<any> {
return Promise.reject(error.message || error);
}
je suppose toPromise()
pas importé correct. Mais je check in node_modules
tous les bûcherons existent et toPromise.d.ts
, toPromise.js
, toPromise.js.map
disponible.
ERREUR:
Severity Code Description Project File Line Suppression State
Error TS2339 Property "toPromise" does not exist on type "Observable<Response>". TypeScript Virtual Projects C:UsersmaxDesktopLocalAccountsApp-masterLocalAccountsAppapphomeGLgl.service.ts 39 Active
Réponses:
0 pour la réponse № 1Ceci est généralement causé par les dernières versions. La solution à ce problème consistera à utiliser les versions RC-4 ou RC-5 avec RX-JS. Vous pouvez avoir un générique
import "rxjs/Rx"
;