ime*_*tuk 5 typescript angular
我已经关注了Angular Tour of Heroes和其他一些教程,现在我正在尝试使用Angular 2构建应用程序.基本上当我们正在使用Subject监听更改时,我们可以等待几秒钟以便请求不会给网络带来负担.
这是我的代码:
import { Injectable } from '@angular/core';
import {Http} from "@angular/http";
import {Observable} from "rxjs/Observable";
import 'rxjs/add/observable/of';
import 'rxjs/add/operator/catch';
import 'rxjs/add/operator/debounceTime';
import 'rxjs/add/operator/distinctUntilChanged';
import 'rxjs/add/operator/switchMap';
import {Employee} from "../employee";
@Injectable()
export class EmployeeSearchService {
private getPersonalURL:string = 'api/employee'; // I'm using mock, btw
constructor(private http:Http) { }
search(term:string): Observable<Employee[]> {
return this.http.get(`api/employee/?firstName=${term}`)
.map(response => response.json().data as Employee[])
.catch(this.handleError);
}
searchEmployees(term: Observable<string>): Observable<Employee[]> {
return term.debounceTime(200)
.distinctUntilChanged()
.switchMap(term => this.search(term)); // here is the error
}
private handleError(error: any): Promise<any> {
console.error('Error on EmployeeSearchService', error);
return Promise.reject(error.message || error);
}
}
Run Code Online (Sandbox Code Playgroud)
这是调用组件:
import { Component, OnInit } from '@angular/core';
import {Subject} from "rxjs/Subject";
import { EmployeeService } from '../employee.service';
import { Employee } from '../employee'
import {EmployeeSharedService} from "../employee-shared.service";
import {EmployeeSearchService} from "../employee-search/employee-search.service";
@Component({
selector: 'employee-list',
providers: [ EmployeeService ],
templateUrl: './employee-list.component.html',
styleUrls: ['./employee-list.component.css']
})
export class EmployeeListComponent implements OnInit {
employees: Employee[];
selectedEmployee: Employee;
sortAsc: boolean;
searchQuery = new Subject<string>();
constructor(private employeeService:EmployeeService, private employeeSearchService:EmployeeSearchService, private employeeSharedService:EmployeeSharedService) {
this.sortAsc = true;
}
ngOnInit() { // called from here
this.employeeSearchService.searchEmployees(this.searchQuery)
.subscribe(result => {
this.employees = result;
if(!result) {
this.getAllEmployees();
}
});
}
getAllEmployees(): void {
// calling get all in service
}
}
Run Code Online (Sandbox Code Playgroud)
有错误说
TypeError: term.debounceTime(...).distinctUntilChanged(...).switchMap is not a function
Run Code Online (Sandbox Code Playgroud)
我错过了什么东西,比如进口或其他东西?因为确切的代码和导入与Angular Tour of Heroes教程和我的作品相同.但这个不是.
Pie*_*Duc 22
您还需要添加switchMap运算符:
import 'rxjs/add/operator/switchMap';
Run Code Online (Sandbox Code Playgroud)
罪魁祸首就是这里
searchQuery = new Subject<string>();
ASubject不是可观察的,但您的函数需要一个可观察的,因此请像这样修改它
ngOnInit() {
this.employeeSearchService.searchEmployees(this.searchQuery.asObservable())...
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
9857 次 |
| 最近记录: |