内容分发

插槽slot

在vue.js中我们使用<slot>元素作为承载分发内容的出口,作者称其为插槽。可以应用在组合组件的场景中

我们准备制作一个待办事项组件(todo),该组件由代办标题(todo-title)和代办内容(todo-items)组成。

第一步:定义一个待办事项的组件

第二步:让待办事项的标题和值实现动态绑定,留出一个插槽

    1.将上面的代码留出一个插槽,即slot

    2.定义一个名为todo-title的代办标题组件和todo-items的待办内容组件

    3.实例化Vue并初始化数据

    4.将这些值,通过插槽插入

我们的todo-title和todo-items组件分别被分发到了todo组件的todo-title和todo-items插槽中

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>

<div id="app">
    <todo>
        <todo-title slot="todo-title" v-bind:title="title"></todo-title>
        <todo-items slot="todo-items" v-for="item in todoItems" v-bind:item="item"></todo-items>
    </todo>
</div>

<script src="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.min.js"></script>
<script>
    //插槽
    Vue.component("todo",{
        template: '<div>\
                        <slot name="todo-title"></slot>\
                        <ul>\
                            <slot name="todo-items"></slot>\
                        </ul>\
                    </div>'
    });
    Vue.component("todo-title",{
        props: ['title'],
        template: '<div>{{title}}</div>'
    });
    Vue.component("todo-items",{
        props: ['item'],
        template: '<li>{{item}}</li>'
    });
    var vm = new Vue({
        el : "#app",
        data: {
            title:'小明学习计划',
            todoItems: ['小明学Java','小明学前端','小明学Linux']
        }
    });
</script>
</body>
</html>

 

自定义事件

  通过以上代码不难发现,数据项在Vue的实例中,但删除操作要在组件中完成,那么组件如何才能删除Vue实例中的数据呢?此时就涉及到了参数传递与事件分发了,Vue为我们提供了自定义时间的功能很好的帮助我们解决了这个问题,

使用this.$emit('  自定义事件名 ',参数),操作过程如下:

1.在vue实例中,增加了methods对象并定义了一个名为removeItems的方法

 2.在组件中定义删除按钮以及remove方法

 3很明显我们只要在这里能调用到vue实例中的removeItems方法就好了,这个时候我们就需要用到this.$emit('  自定义事件名 ',参数)

 4.上面的参数'  remove '是自定义事件名,在视图进行绑定。

 我们看到,我们绑定了下标,事件。这里我们自定义remove绑定vue实例中的removeItems方法,而组件中的remove方法又绑定了这里的remove,这样就实现了,在组件中调用vue实例的方法。即实现了在组件中完成删除vue实例中数据的操作

posted on 2022-12-08 17:07  键盘敲烂的朱  阅读(46)  评论(0编辑  收藏  举报