我对solt的理解是当组件中某一项需要单独定义,那么就应该使用solt。 举例说明。例如项目中需要一个模态框提示 付款成功,付款失败。那么这个模态框也就仅仅差这几个字或者是状态图片而已。那么此时应用solt就是一个非常不错的选择。
最初在 <slot> 标签中的任何内容都被视为备用内容。备用内容在子组件的作用域内编译,并且只有在宿主元素为空,且没有要插入的内容时才显示备用内容。
单个slot情况
//index.html<!DOCTYPE html><html><head><meta charset="utf-8"><title>Vue 测试实例 - 菜鸟教程(runoob.com)</title><script class="lazyload" src="" data-original="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script></head><body><div id="app"> <ol> <children :todo="sites"> <span>你是谁</span> </children> </ol></div><!-- <slot><a href="">默认效果</a></slot> --><script>new Vue({ el: '#app', components:{ 'children': { props: ['todo'], template: '<div><li>{{ todo }}</li></div>' } }, data: { sites: 'Runoob' } })</script></body></html>
输出结果:
我们发现写在 children模板内部的span被默认删除了。如果想让span显示那么此刻就应该使用slot。
代码实例:对index.html的代码做如下修改
//index.html<!DOCTYPE html><html><head><meta charset="utf-8"><title>Vue 测试实例 - 菜鸟教程(runoob.com)</title><script class="lazyload" src="" data-original="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script></head><body><div id="app"> <ol> <children :todo="sites"> <span>你是谁</span> </children> </ol></div><script>new Vue({ el: '#app', components:{ 'children': { props: ['todo'], template: '<div><li>{{ todo }}</li><slot><a href="">默认效果</a></slot></div>' } }, data: { sites: 'Runoob' } })</script></body></html>
那么此时span标签的内容就被渲染出来了。如果在childrem中如果不写span标签那么slot默认会渲染slot里面的内容。
具名slot
上面案例中讲解的是当组件的模板中有一个slot的方法,那么一个组件中如果想使用多个slot那么此时就应该使用具名slot。<slot> 元素可以用一个特殊的属性 name 来配置如何分发内容。多个 slot 可以有不同的名字。具名 slot 将匹配内容片段中有对应 slot 特性的元素。仍然可以有一个匿名 slot ,它是默认 slot ,作为找不到匹配的内容片段的备用插槽。如果没有默认的 slot ,这些找不到匹配的内容片段将被抛弃。
代码实例:对index.html的代码做如下修改:
<!DOCTYPE html><html><head><meta charset="utf-8"><title>Vue 测试实例 - 菜鸟教程(runoob.com)</title><script class="lazyload" src="" data-original="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script></head><body><div id="app"> <ol> <todo-item :todo="sites"> <div slot="header"> <p>我是header</p> </div> <div> 这个是默认的没有具名的solt </div> <div slot="footer"> <p>我是footer</p> </div> </todo-item> </ol></div><script>new Vue({ el: '#app', components:{ 'todo-item': { props: ['todo'], template: '<div><slot name="header"><a href="">默认效果1</a></slot><li>{{ todo }}</li><slot name="footer"><a href="">默认效果2</a></slot></div>' } }, data: { value:"", sites: 'Runoob', } })</script></body></html>
给slot添加事件并通过props将改变的数据value值传递给子组件children
代码实例:对index.html的代码做如下修改:
//index.html<!DOCTYPE html><html><head><meta charset="utf-8"><title>Vue 测试实例 - 菜鸟教程(runoob.com)</title><script class="lazyload" src="" data-original="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script></head><body><div id="app"> <ol> <todo-item :todo="sites" :getvalues="value"> <div slot="header"> <p @click="clickme">{{value}}</p> </div> <div> 这个是默认的没有具名的solt </div> <div slot="footer"> <p>我是footer</p> </div> </todo-item> </ol></div><script>new Vue({ el: '#app', components:{ 'todo-item': { props: ['todo','getvalues'], template: '<div><slot name="header"><a href="">默认效果1</a></slot><li>{{ todo }}----{{getvalues}}</li><slot name="footer"><a href="">默认效果2</a></slot></div>' } }, data: { value:"空空如也", sites: 'Runoob', }, methods:{ clickme(){ this.value="我是传过来的header"; } } })</script></body></html>
点击“点我试试”后结果如下如所示:
作者:world_7735
链接:https://www.jianshu.com/p/4128e297f24d
点击查看更多内容
为 TA 点赞
评论
共同学习,写下你的评论
评论加载中...
作者其他优质文章
正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦