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


Posted in Javascript onJune 13, 2017

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

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

Vue.component('father-component1',{
  template:'<div class="father"><p>Hi,我是父组件</p>{{fatherMessage}}</div>',
  data:function(){
   return {
     fatherMessage:'这是父组件发出的消息哦~'
   }
  },
});

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

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

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

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

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

怎么获取呢?

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

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

//js
Vue.component('child-component4',{
  template:'<ul>' +
  '<slot name="child-ul" v-for="item in fruit" v-bind:text="item.name">?</slot>' +
  '</ul>',
  data:function(){
   return {
     fruit:[
       {name:'苹果'},
       {name:'香蕉'},
       {name:'橙子'}
     ]
   }
  },
});
Vue.component('father-component4',{
  template:'<child-component4>' +
  '<template scope="props" slot="child-ul">' +
  '<li class="child-li" >{{props.text}}</li>' +
  '</template>' +
  '</child-component4>'
});
var app16 = new Vue({
  el:'#app16'
});
<div id="app16">
  <father-component4></father-component4>
</div>

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

<div id="app16">
<ul>
  <li class="child-li">苹果</li>
  <li class="child-li">香蕉</li>
  <li class="child-li">橙子</li>
</ul>
</div>

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

Javascript 相关文章推荐
Javascript 不能释放内存.
Sep 07 Javascript
js报错 Object doesn't support this property or method的原因分析
Mar 31 Javascript
jQuery自带的一些常用方法总结
Sep 03 Javascript
jquery制作多功能轮播图插件
Apr 02 Javascript
JavaScript控制网页层收起和展开效果的方法
Apr 15 Javascript
jQuery EasyUI Dialog拖不下来如何解决
Sep 28 Javascript
jQuery实现弹出带遮罩层的居中浮动窗口效果
Sep 12 Javascript
微信小程序 教程之注册程序
Oct 17 Javascript
js实现文字选中分享功能
Jan 25 Javascript
D3.js中强制异步文件读取同步的几种方法
Feb 06 Javascript
easyui简介_动力节点Java学院整理
Jul 14 Javascript
JavaScript中引用vs复制示例详析
Dec 06 Javascript
Javascript实现从小到大的数组转换成二叉搜索树
Jun 13 #Javascript
微信小程序实现移动端滑动分页效果(ajax)
Jun 13 #Javascript
详解AngularJs路由之Ui-router-resolve(预加载)
Jun 13 #Javascript
微信小程序动态显示项目倒计时效果
Jun 13 #Javascript
深究AngularJS之ui-router详解
Jun 13 #Javascript
微信小程序自定义导航隐藏和显示功能
Jun 13 #Javascript
深究AngularJS——ng-checked(回写:带真实案例代码)
Jun 13 #Javascript
You might like
php radio 单选框获取与保持值的实现代码
2010/05/15 PHP
php 模拟get_headers函数的代码示例
2013/04/27 PHP
php 批量替换程序的具体实现代码
2013/10/04 PHP
PHP实现通用alert函数的方法
2015/03/11 PHP
ExtJS4 组件化编程,动态加载,面向对象,Direct
2011/05/12 Javascript
三种方式获取XMLHttpRequest对象
2014/04/21 Javascript
Jquery判断form表单数据是否变化
2016/03/30 Javascript
Centos7 中 Node.js安装简单方法
2016/11/02 Javascript
微信小程序 后台登录(非微信账号)实例详解
2017/03/31 Javascript
基于Vue实现后台系统权限控制的示例代码
2017/08/29 Javascript
vue 中动态绑定class 和 style的方法代码详解
2018/06/01 Javascript
Vue中的vue-resource示例详解
2018/11/02 Javascript
Laravel admin实现消息提醒、播放音频功能
2019/07/10 Javascript
vue 中固定导航栏的实例代码
2019/11/01 Javascript
JavaScript布尔运算符原理使用解析
2020/05/06 Javascript
JS实现小米轮播图
2020/09/21 Javascript
[01:07:02]DOTA2-DPC中国联赛 正赛 iG vs PSG.LGD BO3 第三场 2月26日
2021/03/11 DOTA
举例讲解Python设计模式编程的代理模式与抽象工厂模式
2016/01/16 Python
python django事务transaction源码分析详解
2017/03/17 Python
python中安装Scrapy模块依赖包汇总
2017/07/02 Python
python3中datetime库,time库以及pandas中的时间函数区别与详解
2020/04/16 Python
在django admin中配置搜索域是一个外键时的处理方法
2020/05/20 Python
Python 连接 MySQL 的几种方法
2020/09/09 Python
StubHub墨西哥:购买和出售您的门票
2016/09/17 全球购物
Clarria化妆品官方网站:购买天然和有机化妆品系列
2018/04/08 全球购物
MySQL面试题目集锦
2016/04/14 面试题
应届毕业生自荐信例文
2014/02/26 职场文书
消防标语大全
2014/06/07 职场文书
促销活动总结模板
2014/07/01 职场文书
批评与自我批评范文
2014/10/15 职场文书
2014年公司工作总结
2014/11/22 职场文书
劳动纠纷调解协议书格式
2014/11/30 职场文书
职代会闭幕词
2015/01/28 职场文书
2015年法制宣传月活动总结
2015/03/26 职场文书
“学党章、守党纪、讲党规”学习心得体会
2016/01/14 职场文书
分享:关于学习的励志名言赏析
2019/08/16 职场文书