我想創建一個模擬服務如下。 我的服務是一樣訂閱方法不適用於observable?
import { Injectable } from '@angular/core';
import { URLSearchParams } from '@angular/http';
import { Observable } from 'rxjs/Observable';
import { Config } from '../../shared/config/env.config';
import { HttpBaseService } from '../../shared/http-base/http-base.service';
import { ResponseModel } from '../../shared/models/index';
import { InventoryIntake } from './inventoryintake';
@Injectable()
export class InventoryIntakeService {
list:InventoryIntake[];
constructor(private http: HttpBaseService) { }
get(): Observable<ResponseModel<InventoryIntake[]>> {
this.list=[{
supplier_name:"atami",
metric_reference:"55665589",
date_received:new Date("10-5-2017"),
date_transferred:new Date("15-5-2017")
},
{
supplier_name:"green bits",
metric_reference:"4555589",
date_received:new Date("10-5-2017"),
date_transferred:new Date("15-5-2017")
}]
let response = new ResponseModel<InventoryIntake[]>();
response.data = this.list;
console.log("called")
return Observable.create(response);
}
}
和成分,我呼籲像
import { Component, OnInit } from '@angular/core';
import { ActivatedRoute, Router } from '@angular/router';
import { URLSearchParams } from '@angular/http';
import { HttpBaseService } from '../../shared/http-base/http-base.service';
import {InventoryIntakeService} from './inventoryintake.service';
import {InventoryIntake} from './inventoryintake'
@Component({
moduleId: module.id,
selector: 'inventory-report',
templateUrl: './inventoryintake.component.html',
providers: [ HttpBaseService,InventoryIntakeService]
})
export class InventoryIntakeComponent implements OnInit {
inventoryintake_list: InventoryIntake[] = [];
constructor(
private route: ActivatedRoute, private router: Router,private InventoryIntakeService:InventoryIntakeService) {
}
getIntakeList(): void {
this.InventoryIntakeService.get()
.subscribe((inventoryintake_list) => {
this.inventoryintake_list = inventoryintake_list.data;
console.log(this.inventoryintake_list);
})
}
ngOnInit(): void {
this.getIntakeList();
}
}
}
當我這樣做。 iam得到錯誤,說.subscribe不是一個函數。 我該如何解決這個問題?
如何創建一個可觀察返回類型的模擬服務? 問題是用可觀察的創建方法嗎?
代碼'this.InventoryIntakeService.get()'甚至不應該編譯。請向我們展示更多的組件代碼,包括構造函數。 – 2017-09-01 06:25:50
代碼已更新... –