详解Vue.js分发之作用域槽

前端之家收集整理的这篇文章主要介绍了详解Vue.js分发之作用域槽前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

首先,需要知道的是,每个组件有每个组件自己的作用域。每个组件都是Vue()的实例,有自己的作用域。

比如现在有个组件这样的:

Hi,我是父组件

{{fatherMessage}}
',data:function(){ return { fatherMessage:'这是父组件发出的消息哦~' } },});

这个data只为template里的模板服务。同样的,子组件的data只为子组件的模板服务。因为他们都是各自作用域内的属性

在slot分发中,无论是单分发还是具名分发,都是父组件替换子组件的数据,或者没有替换,用子组件默认的数据。两者并不能共存。这样他们就没有数据联系了。

但是通过设置作用域槽,就可以改变这种状况,让子组件可以在父组件进行分发时获取自己的数据,至于是什么数据,由子组件决定,这样就能解耦了。

作用域槽通过slot的一个自定义属性,官方给出的DEMO是text,但也可以是其他,值为暴露的数据。

这个自定义属性已经存放在子组件的prop对象里了。等待着被父组件获取

怎么获取呢?

在父组件的模板里,使用一个Vue自带的特殊组件