码迷,mamicode.com
首页 > 其他好文 > 详细

vue2.0 slot 分发内容

时间:2017-09-30 16:23:32      阅读:178      评论:0      收藏:0      [点我收藏+]

标签:按钮   没有   images   如何   简单   作用域   http   添加   不同的   

1.概述:

简单来说,假如父组件需要在子组件内放一些DOM,那么这些DOM是显示、不显示、在哪个地方显示、如何显示,就是slot分发负责的活。

 

2.默认情况下

父组件在子组件内套的内容,是不显示的。

代码:

技术分享

 

 

效果图:

技术分享

 

显示内容是一个button按钮,不包含span标签里面的内容;

 

3.单个slot

简单来说,只使用这个标签的话,可以将父组件放在子组件的内容,放到想让他显示的地方。

代码:

技术分享

例如这样写的话,结果是:

<button><span>12345</span>为了明确作用范围,所以使用button标签</button>

效果图:

技术分享

即父组件放在子组件里的内容,插到了子组件的<slot></slot>位置;

注意,即使有多个标签,会一起被插入,相当于用父组件放在子组件里的标签,替换了<slot></slot>这个标签。

技术分享  技术分享

 

4.具体命名 slot

 

将放在子组件里的不同html标签放在不同的位置

父组件在要分发的标签里添加 slot=”name名” 属性

子组件在对应分发的位置的slot标签里,添加 name=”name名” 属性,

然后就会将对应的标签放在对应的位置了。

代码:

技术分享

显示结果为:

<button>
    <span slot="first">12345</span>
    为了明确作用范围,
    <span slot="second">56789</span>
    所以使用button标签
</button>

效果图:

技术分享

 

5.分发内容的作用域:

被分发的内容的作用域,根据其所在模板决定,例如,以上标签,其在父组件的模板中(虽然其被子组件的children标签所包括,但由于他不在子组件的template属性中,因此不属于子组件),则受父组件所控制。

代码:

技术分享

 

 

6.当没有分发内容时的提示:

假如父组件没有在子组件中放置有标签,或者是父组件在子组件中放置标签,但有slot属性,而子组件中没有该slot属性的标签。

那么,子组件的slot标签,将不会起到任何作用。

除非,该slot标签内有内容,那么在无分发内容的时候,会显示该slot标签内的内容。

代码:

技术分享

 

效果图:

技术分享

 

7.假如想控制子组件根标签的属性

(1)

(2)

vue2.0 slot 分发内容

标签:按钮   没有   images   如何   简单   作用域   http   添加   不同的   

原文地址:http://www.cnblogs.com/crazycode2/p/7615050.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!