gpt4 book ai didi

javascript - 在vue中删除列表中的对象时出错

转载 作者:行者123 更新时间:2023-11-30 14:08:24 24 4
gpt4 key购买 nike

我正在使用 vue.js 部署客户端应用程序。在这个应用程序中,我有一些使用 v-for 呈现的选项卡。此选项卡数组在 vuex 存储中的格式如下:

tabs: [
{
id: 1,
title: 'first tab',
number: '09389826331',
accountName: 'DelirCo',
contactName: 'PourTabarestani',
startTime: '2019-02-25 15:11:30',
endTime: '2019-02-25 18:04:10',
duration: null,
subject: '',
description: ''
},
{
id: 2,
title: 'second tab',
number: '09124578986',
accountName: 'Cisco',
accountGUID: '',
contactName: 'Arcada',
contactGUID: '',
startTime: '2019-02-25 15:11:45',
endTime: '2019-02-25 15:13:55',
duration: null,
subject: '',
description: ''
}
]

我正在使用 getter 加载我的 vuex 商店中的选项卡,它使用以下模板呈现选项卡:

<template>
<div id="Tabs">
<vs-tabs color="#17a2b8" v-model="selectedTab">
<vs-tab v-for="tab in tabs" :key="tab.id" :vs-
label="tab.title">
<Tab :tab="tab"></Tab>
</vs-tab>
</vs-tabs>
</div>
</template>

我正在使用 vuesax 组件来创建选项卡显示。此列表中的每个对象都是我前端的一个选项卡,当我单击每个选项卡时,它会显示相关数据。当我尝试显示选项卡或什至在数组中添加另一个对象时,它表现得非常好。问题是当我尝试从此数组中删除某个项目时,内容消失但选项卡标题(我可以用它选择选项卡的按钮)保留在页面上。我正在使用

state.tabs.splice(objectIndex, 1)
state.selectedTab -= 1

用于删除选项卡并将所选选项卡更改为上一个选项卡。但正如我所说,标签的标题并没有像下图那样被删除:

picture当我单击该选项卡时,出现此错误:

webpack-internal:///./node_modules/vuesax/dist/vuesax.common.js:4408 Uncaught TypeError: Cannot set property 'invert' of undefined
at VueComponent.activeChild (webpack-internal:///./node_modules/vuesax/dist/vuesax.common.js:4408)
at click (webpack-internal:///./node_modules/vuesax/dist/vuesax.common.js:4127)
at invoker (webpack-internal:///./node_modules/vue/dist/vue.esm.js:2140)
at HTMLButtonElement.fn._withTask.fn._withTask (webpack-internal:///./node_modules/vue/dist/vue.esm.js:1925)

有人对这件事有什么建议吗?

最佳答案

您可以只向父元素添加一个键来强制重新渲染。

<div :key="forceRender">
<vs-tabs :value="activeTab">
<template v-for="item in items">
<vs-tab :label="item.name" @click="onTabChange(item)">
<div class="con-tab-ejemplo">
<slot name="content"></slot>
</div>
</vs-tab>
</template>
</vs-tabs>
</div>

之后在 items 上添加观察者:

watch: {
items (val) {
this.forceRender += 1
}
},

关于javascript - 在vue中删除列表中的对象时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54924181/

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