详解Vue.js分发之作用域槽_vue.js_脚本之家

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

前面的话

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

为了让组件可以组合,需要一种方式来混合父组件的内容与子组件自己的模板。这个过程被称为
内容分发 。Vue实现了一个内容分发 API,参照了当前 Web
组件规范草案,使用特殊的
元素作为原始内容的插槽。本文将详细介绍Vue内容分发slot

Vue.component('father-component1',{ template:'{{fatherMessage}}', data:function(){ return { fatherMessage:'这是父组件发出的消息哦~' } },});

编译作用域

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

在深入内容分发 API 之前,先明确内容在哪个作用域里编译。假定模板为

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

 {{ message }}

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

message
应该绑定到父组件的数据,还是绑定到子组件的数据?答案是父组件。组件作用域简单地说是:父组件模板的内容在父组件作用域内编译;子组件模板的内容在子组件作用域内编译。

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

一个常见错误是试图在父组件模板内将一个指令绑定到子组件的属性/方法:

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

假定someChildProperty是子组件的属性,上例不会如预期工作。父组件模板不应该知道子组件的状态

怎么获取呢?

如果要绑定作用域内的指令到一个组件的根节点,应当在组件自己的模板上做:

在父组件的模板里,使用一个Vue自带的特殊组件
,并在该组件上使用scope属性,值是一个临时的变量,存着的是由子组件传过来的prop对象,在下面的例子中我把他命名为props。

Vue.component('child-component', { // 有效,因为是在正确的作用域内 template: 'Child', data: function () { return { someChildProperty: true } }})

获得由子传过来的prop对象。这时候,父组件就可以访问子组件在自定义属性上暴露的数据了。

类似地,分发内容是在父作用域内编译

//jsVue.component('child-component4',{ template:'

默认丢弃

‘, data:function(){ return { fruit:[ {name:’苹果’}, {name:’香蕉’},
{name:’橙子’} ] } },});Vue.component(‘father-component4’,{ template:”

一般地,如果子组件模板不包含插口,父组件的内容将会被丢弃

  • ” + ‘
var parentNode = { template: `       `, components: { 'child': childNode },};

 var childNode = { template: ` <div >  </div> `,};var parentNode = { template: ` <div >  <child>  </child> </div> `, components: { 'child': childNode },};// 创建根实例new Vue({ el: '#example', components: { 'parent': parentNode }})

{{props.text}}

如下图所示,所包含的被丢弃

‘ + ” + ”});var app16 = new Vue;

匿名slot

以上的的组件组合会被渲染为:

当子组件模板只有一个没有属性的 slot 时,父组件整个内容片段将插入到 slot
所在的 DOM 位置,并替换掉 slot 标签本身

 苹果 香蕉 橙子
var childNode = { template: `     `,};

var parentNode = { template: `       `, components: { 'child': childNode },};

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

如果出现多于1个的匿名slot,vue将报错

var childNode = { template: `      `,};

最初在 “
标签中的任何内容都被视为备用内容,或者称为默认值。备用内容在子组件的作用域内编译,并且只有在宿主元素为空,且没有要插入的内容时才显示备用内容

当slot存在默认值,且父元素在中没有要插入的内容时,显示默认值

var childNode = { template: `     `,};var parentNode = { template: `     `, components: { 'child': childNode },};

当slot存在默认值,且父元素在中存在要插入的内容时,则显示设置值