gpt4 book ai didi

javascript - 类型 'subscribe' 上不存在属性 'void'。 Angular 2 ASP.NET 核心

转载 作者:太空狗 更新时间:2023-10-29 16:53:31 26 4
gpt4 key购买 nike

当我尝试使用订阅时出现以下错误。我与 .map 有同样的问题,但我通过替换以下文件解决了这个问题 https://raw.githubusercontent.com/Microsoft/TypeScript/Fix8518/lib/typescriptServices.js

我已经将 Typescript 更新到 1.8.6,并将 visual studio 2015 更新到 update 3。

我不知道如何解决这个问题,或者如果我做错了什么,我也添加了

import 'rxjs/Rx'; 

到 bootstrap 和 app.component 类,仍然是同样的错误。

服务代码:

import { Injectable } from 'angular2/core';
import {Http, URLSearchParams} from "angular2/http";
import 'rxjs/add/operator/map';

@Injectable()
export class MediaItemService {

constructor(public http: Http) {
this.http = http;
}

//functions
get() {
// return this.mediaItems;
this.http.get("/api/MediaItem").map(response => { response.json() });
}
}

使用服务的类:

import {Component, Inject} from 'angular2/core';
import 'rxjs/Rx';
import {MediaItemComponent} from './media-item.component';
import {CategoryListPipe} from './category-list.pipe';
import {MediaItemService} from './media-item.service';

@Component({
selector: 'media-item-list',
directives: [MediaItemComponent],
pipes: [CategoryListPipe],
providers: [MediaItemService],
templateUrl: 'app/media-item-list.component.html',
styleUrls: ['app/media-item-list.component.css']
})
export class MediaItemListComponent {


constructor(private mediaItemService: MediaItemService) {

//.subscribe(mediaItems => {
// this.mediaItems = mediaItems;
//});
}

ngOnInit() {
this.mediaItems = this.mediaItemService.get().subscribe(mediaItems => {
this.mediaItems = mediaItems;
});
}

onMediaItemDeleted(mediaItem) {

this.mediaItemService.delete(mediaItem);
}

mediaItems;
}

package.json 文件:

{
"version": "1.0.0",
"name": "TestFunWithAngi",
"private": true,
"dependencies": {
"angular2": "^2.0.0-beta.17",
"systemjs": "^0.19.31",
"es6-promise": "^3.2.1",
"es6-shim": "^0.35.1",
"reflect-metadata": "^0.1.3",
"rxjs": "^5.0.0-beta.9",
"tsd": "^0.6.5",
"zone.js": "^0.6.12"
},
"devDependencies": {
"typescript": "^1.8.10",
"typings": "^0.8.1",
"grunt": "1.0.1",
"grunt-contrib-copy": "1.0.0",
"grunt-contrib-uglify": "1.0.1",
"grunt-contrib-watch": "1.0.0",
"grunt-ts": "5.5.1"

}
}

最佳答案

您忘记在 get() 中返回。也不要在不返回任何东西的情况下封装 lambda 函数的主体。如果您只是执行 response => response.json(),就会发生隐式返回。否则你必须这样写: response => { return response.json();

这是您的方法的改进版本:

get() {
// return this.mediaItems;
return this.http.get("/api/MediaItem").map(response => response.json());
}

也只需在构造函数中省略 this.http = http; 即可。在构造函数参数前写上 publicprivate 已经将其添加为类成员。

关于javascript - 类型 'subscribe' 上不存在属性 'void'。 Angular 2 ASP.NET 核心,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37990993/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com