大家好:
最近在学习 Vue,模仿官网的树形视图列表例子练习,想为其增加一个删除列表项的功能,但是不知道该如何实现。我的代码如下:
<script type="text/x-template" id="item-template">
<li>
<div
@dblclick="changeType"
:class="{bold: isFolder}">
{{ model.name }}
<span
@click="toggle"
v-if="isFolder"
>[ {{ open ? '-' : '+' }} ]
</span>
// 想点击这个按钮后删除对应的列表项
<span
@click="deleteItem"
v-if="!isFolder"
> [x]
</span>
</div>
<ul v-show="open" v-if="isFolder">
<item
v-for="(m, index) in model.children"
:model="m"
:key="index"
/>
<li @click="add">+</li>
</ul>
</li>
</script>
Vue.component('item', {
template: '#item-template',
props: {
model: Object
},
data: function () {
return {open: false}
},
computed: {
isFolder: function () {
return this.model.children
}
},
methods: {
toggle: function () {
this.open = !this.open
},
add: function () {
this.model.children.push({name: 'new stuff'})
},
changeType: function () {
if (!this.isFolder) {
Vue.set(this.model, 'children', []);
this.add()
}
},
deleteItem: function () {
// 不知道该如何删除被点击的按钮对应的列表项
}
}
});
谢谢大家的指点!
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.