新手学习 Vue 官网的树形列表例子求助

2018-04-08 14:49:01 +08:00
 chuanqirenwu

大家好:

最近在学习 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 () {
				// 不知道该如何删除被点击的按钮对应的列表项
            }
        }
    });

谢谢大家的指点!

2148 次点击
所在节点    Vue.js
2 条回复
overflowHidden
2018-04-08 15:35:03 +08:00
删除事件可以传一个删除项的 index 进去,model.children 去掉相应项( splice), 重新渲染就 ok 了。建议把删除事件绑定到列表项上。
chuanqirenwu
2018-04-08 18:30:29 +08:00
@overflowHidden 绑定到列表项点击整个列表都会删除,这不是想要的结果吧?

我看看 index 能否获取。

谢谢你的指点!

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/445066

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX