详解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 动态加载 css 方法总结
Jul 11 Javascript
模拟select的代码
Oct 19 Javascript
js调用activeX获取u盘序列号的代码
Nov 21 Javascript
回车直接实现点击某按钮的效果即触发单击事件
Feb 27 Javascript
Node.js中child_process实现多进程
Feb 03 Javascript
浅析JS异步加载进度条
May 05 Javascript
利用JavaScript实现拖拽改变元素大小
Dec 14 Javascript
bootstrap实现每隔5秒自动轮播效果
Dec 20 Javascript
js实现背景图自适应窗口大小
Jan 10 Javascript
原生JS实现的自动轮播图功能详解
Dec 28 Javascript
微信小程序封装的HTTP请求示例【附升级版】
May 11 Javascript
微信小程序 如何获取网络状态
Jul 26 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
地摊中国 - 珍藏老照片
2020/08/18 杂记
php 中的4种标记风格介绍
2012/05/10 PHP
PHP中的reflection反射机制测试例子
2014/08/05 PHP
php中ftp_chdir与ftp_cdup函数用法
2014/11/18 PHP
Joomla使用Apache重写模式的方法
2016/05/04 PHP
Apache无法自动跳转却显示目录的解决方法
2020/11/30 PHP
php接口技术实例详解
2016/12/07 PHP
PHP jQuery+Ajax结合写批量删除功能
2017/05/19 PHP
PHP实现的简单组词算法示例
2018/04/10 PHP
PHP+redis实现微博的拉模型案例详解
2019/07/10 PHP
十个优秀的Ajax/Javascript实例网站收集
2010/03/31 Javascript
jQuery中json对象的复制方式介绍(数组及对象)
2013/06/08 Javascript
jQuery.Sumoselect插件实现下拉复选框效果
2017/11/09 jQuery
原生JS进行前后端同构
2018/04/22 Javascript
vue项目中vue-i18n和element-ui国际化开发实现过程
2018/04/25 Javascript
angularjs实现的购物金额计算工具示例
2018/05/08 Javascript
React项目动态设置title标题的方法示例
2018/09/26 Javascript
js实现弹出框的拖拽效果实例代码详解
2019/04/16 Javascript
Vue项目中Api的组织和返回数据处理的操作
2019/11/04 Javascript
jQuery 选择器用法实例分析【prev + next】
2020/05/22 jQuery
微信公众号网页分享功能开发的示例代码
2020/05/27 Javascript
解决echarts中横坐标值显示不全(自动隐藏)问题
2020/07/20 Javascript
JS实现简易图片自动轮播
2020/10/16 Javascript
[48:20]OpTic vs Serenity 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
python网络编程之TCP通信实例和socketserver框架使用例子
2014/04/25 Python
Python中super函数用法实例分析
2019/03/18 Python
手把手教你配置JupyterLab 环境的实现
2021/02/02 Python
使用css3实现的windows8开机加载动画
2014/12/09 HTML / CSS
La Senza官网:北美顶尖性感内衣品牌
2018/08/03 全球购物
欧洲领先的火车票和大巴票预订平台:Trainline
2018/12/26 全球购物
英国老牌潮鞋店:Offspring
2019/08/19 全球购物
日本化妆品植村秀俄罗斯官方网站:Shu Uemura俄罗斯
2020/02/01 全球购物
学校领导班子四风问题整改意见
2014/10/02 职场文书
工作犯错保证书
2015/05/11 职场文书
小学数学教师研修感悟
2015/11/18 职场文书
党员读书活动心得体会
2016/01/14 职场文书