gpt4 book ai didi

Angular 2 使用 Http Observable 和 Pipe

转载 作者:搜寻专家 更新时间:2023-10-30 21:24:22 25 4
gpt4 key购买 nike

我有一个调用 REST 端点的服务:

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]);
}
}

最佳答案

在 ajax 尚未完成的初始更改检测周期中,它会尝试评估 bindings并通过 tasks中的值 undefinedWithStatus管道并抛出错误。对于这种情况,您只能在 Pipe 中处理它。

@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]);
}
}

另一种方法是你应该注入(inject) task-details DOM 树中的 DOM,直到 ajax 使用 *ngIf 成功结构指令。

<template [ng-if]="tasks">
<task-details
*ngFor="let task of tasks | WithStatus: TaskStatus.New"
[task]="task">
</task-details>
</template>

而不是 <template>你也可以使用 <ng-container>它允许使用与内联 *ngIf 相同的语法:

<ng-container *ngIf="tasks">
<task-details
*ngFor="let task of tasks | WithStatus: TaskStatus.New"
[task]="task">
</task-details>
</ng-container>

关于Angular 2 使用 Http Observable 和 Pipe,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39678104/

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