gpt4 book ai didi

javascript - 如何删除(删除)对象数组中的特定项目

转载 作者:行者123 更新时间:2023-11-29 18:45:35 24 4
gpt4 key购买 nike

我想使用删除函数删除数组中的特定对象。

我尝试了 splice() 方法,但无论我点击了哪个对象,它都只会删除第一个数组

这是带有 v-for 方法的对象的代码

 <li v-for=" skill in skills" :key="skill.id">
{{skill.skill}}
<i class="fa fa-minus-circle v-on:click="remove(skill)"></i>
</li>

这是 Skill.vue

 <script>
import uuid from "uuid";
export default {
name: "Skills",
data() {
return {
skill: "",
skills: [
{ id: uuid.v4(), skill: "Vue.js" },
{
id: uuid.v4(),
skill: "Javascript"
},
{
id: uuid.v4(),
skill: "Rails"
}
]
};
},
methods: {
addSkill() {
this.$validator.validateAll().then(result => {
if (result) {
this.skills.push({ skill: this.skill, id: uuid.v4() });
this.skill = "";
}
});
},
remove(id) {
this.skills.splice(id, 1);
}
}

};

如何构造方法

remove(id) {
this.skills.splice(id, 1);
}

删除特定对象?

最佳答案

要使用splice(),您应该将项目的索引作为参数传递。要根据属性删除项目,请考虑改用 filter()

模板应该是:

<li v-for="skills in skill" :key="skill.id">
{{skill.skill}}
<i class="fa fa-minus-circle v-on:click="remove(skill.id)"></i>
</li>

方法:

remove(id) {
this.skills = this.skills.filter(skill => skill.id !== id);
}

它将返回一个数组副本,不包含 skill.id !== id 计算结果为 false 的项目。

关于javascript - 如何删除(删除)对象数组中的特定项目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54353941/

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