
大家好:
最近在学习 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 () { // 不知道该如何删除被点击的按钮对应的列表项 } } }); 谢谢大家的指点!
1 overflowHidden 2018-04-08 15:35:03 +08:00 删除事件可以传一个删除项的 index 进去,model.children 去掉相应项( splice), 重新渲染就 ok 了。建议把删除事件绑定到列表项上。 |
2 chuanqirenwu OP |