微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

未更新的组件列表

如何解决未更新的组件列表

我让此模板显示组件列表:

<template>
  <v-container id="container">
    <RaceItem v-for="(item,index) in items" :key="item + index" />
  (...)

当更新数组“ items”(shift()或push()一个新项)时,显示的列表未更新。 我确定我在Vue的工作原理上漏了一些东西...但是有人能解释出什么问题吗?

解决方法

可以尝试这样的事情吗 enter image description here

将componentKey放在v容器上,并在完成推送后使用forceRender()

,

key属性期望number | string | boolean | symbol。建议使用基元作为键。

最简单的用法是使用每个元素的原始唯一属性来跟踪它们:

 <RaceItem v-for="item in items" :key="item.id" />

...假设您的items具有唯一的id


如果使用index作为键,则每次更新数组时,都必须将其替换为自身的更新版本(即:this.items = [...items];-其中items包含突变)。

在这种情况下,方法的外观如下:

methods: {
  applyChangeToItem(item,change) {
    // apply change to item and return the modified item
  },updateItem(index,change) {
    this.$set(
      this.items,index,this.applyChangeToItem(this.items[index],change)
    );
  },addItem(item) {
    this.items = [...this.items,item];
  },removeItem(index) {
    this.items = [...this.items.filter((_,i) => index !== i)];
  }
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。