【问题标题】:How to update subscribed value in html on change in Angular?如何在 Angular 更改时更新 html 中的订阅值?
【发布时间】:2021-03-18 16:50:02
【问题描述】:

点击“Edit”后,“editStatus”函数被调用,“order.status”的值发生变化。但 html 视图保持不变 - 显示订单的旧状态。它仅在刷新页面后更改。更改后如何使状态显示更新的变量?

html:

<div *ngIf="order">
    <p>Id:<b> {{ order._id }}</b></p>
    <p>Status:<b> {{ order.status }}</b></p>
</div>
<button (click)="editStatus(order)">Edit</button>

ts 文件:

private subscribe: Subscription;
  order: Order;
  constructor(private orderService: OrderService, private route: ActivatedRoute, public router: Router) { }

  ngOnInit() {
    this.subscribe = this.route.params.pipe(
      map(({ id }) => id),
      switchMap((id: string) => this.orderService.getOrderById(id)))
      .subscribe((res) => {
        this.order = res;
      });
  }
  ngOnDestroy() {
    this.subscribe.unsubscribe();
  }

  editStatus(order) {
    const orderEdited = { order, status: 'order_canceled' };
    this.orderService.editStatus(orderEdited).subscribe(
      res => {
        console.log(res);
      },
      err => console.log(err)
    );
  }

订购服务:

private userOrdersUrl = 'http://localhost:3000/api/auth/user-orders';

getOrderById(orderId): Observable<Order> {
  return this.http.get<Order>(`${this.userOrdersUrl}/${orderId}`);
}
editStatus(order) {
  return this.http.put<Order>(this.userOrdersUrl, order);
}

【问题讨论】:

    标签: html angular typescript ngonchanges


    【解决方案1】:

    看起来像学生作业...

    您没有将更新的顺序分配给您的变量。更改为以下内容:

    res => {
        this.order = res;
    },
    

    【讨论】:

      猜你喜欢
      • 2019-06-05
      • 2019-04-27
      • 1970-01-01
      • 2021-05-14
      • 2018-01-24
      • 2017-10-18
      • 2018-09-08
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多