У меня есть сервис, который называют в REST конечной точки:Угловое 2 Использование Http наблюдаемым и трубы
import { Task } from './task';
import { TaskStatus } from './task-status';
import { Injectable } from '@angular/core';
import { Http } from '@angular/http';
@Injectable()
export class TaskService {
constructor(private http: Http){
}
getTasks() {
return this.http.get('http://localhost:8080/tasks').map(res => res.json()).map(rest => rest._embedded.tasks);
}
}
Конечная точка возвращает результат, как этот:
{
"_embedded": {
"tasks": [
{
"title": "zxc",
"description": "zxc",
"status": "New",
"_links": {
"self": {
"href": "http://localhost:8080/tasks/1"
},
"task": {
"href": "http://localhost:8080/tasks/1"
}
}
},
{
"title": "asd",
"description": "qweqwe",
"status": "New",
"_links": {
"self": {
"href": "http://localhost:8080/tasks/2"
},
"task": {
"href": "http://localhost:8080/tasks/2"
}
}
}
]
},
"_links": {
"self": {
"href": "http://localhost:8080/tasks"
},
"profile": {
"href": "http://localhost:8080/profile/tasks"
}
},
"page": {
"size": 20,
"totalElements": 3,
"totalPages": 1,
"number": 0
}
}
я использую службу в этом компоненте :
@Component({
selector: 'app-mycomp',
templateUrl: './my.component.html',
styleUrls: ['./my.component.css']
})
export class MyComponent implements OnInit {
tasks: Array<Task>;
constructor(private taskService:TaskService) {
taskService.getTasks()
.subscribe(tasks => this.tasks = tasks,
err => console.error(err),
() => console.log('done'));
}
}
И шаблон выглядит следующим образом:
<task-details *ngFor="let task of tasks" [task]="task"></task-details>
Это работает, как ожидалось, но когда я пытаюсь использовать трубу в шаблоне:
<task-details *ngFor="let task of tasks | WithStatus: TaskStatus.New" [task]="task"></task-details>
я получил ошибку «Не удается прочитать свойство„фильтр“неопределенных».
Вот реализация труб:
import { Pipe, PipeTransform } from '@angular/core';
import { TaskStatus } from './task-status';
@Pipe({ name: 'WithStatus', pure: true })
export class TaskStatusFilter implements PipeTransform{
transform(value: any, ...args: any[]): any {
console.log(value);// value is undefined
return value.filter(item => item.status == args[0]);
}
}
'WithStatus: TaskStatus.New', что такое TaskStatus.New? у вас нет такой вещи нигде .... – micronyks