详解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中callee与caller的用法和应用场景
Dec 08 Javascript
JQuery入门—编写一个简单的JQuery应用案例
Jan 03 Javascript
express的中间件cookieParser详解
Dec 04 Javascript
JavaScript获取元素尺寸和大小操作总结
Feb 27 Javascript
JQuery中Text方法用法实例分析
May 18 Javascript
详解BootStrap中Affix控件的使用及保持布局的美观的方法
Jul 08 Javascript
EsLint入门学习教程
Feb 17 Javascript
微信小程序 出现错误:{&quot;baseresponse&quot;:{&quot;errcode&quot;:-80002,&quot;errmsg&quot;:&quot;&quot;}}解决办法
Feb 23 Javascript
jQuery基本选择器和层次选择器学习使用
Feb 27 Javascript
vue 计时器组件的实现代码
Sep 14 Javascript
详解利用Angular实现多团队模块化SPA开发框架
Nov 27 Javascript
js 计数排序的实现示例(升级版)
Jan 12 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使用json_encode函数时不转义中文的解决方法
2014/11/12 PHP
php在windows环境下获得cpu内存实时使用率(推荐)
2018/02/08 PHP
JCalendar 日历控件 v1.0 beta[兼容IE&amp;Firefox] 有文档和例子
2007/05/30 Javascript
Javascript !!的作用
2008/12/04 Javascript
JQuery拖拽元素改变大小尺寸实现代码
2012/12/10 Javascript
js调用后台、后台调用前台等方法总结
2014/04/17 Javascript
jQuery中prepend()方法用法实例
2014/12/25 Javascript
vue.js中指令Directives详解
2017/03/20 Javascript
Angular中的$watch、$watchGroup、$watchCollection
2017/06/25 Javascript
基于vue打包后字体和图片资源失效问题的解决方法
2018/03/06 Javascript
vue组件实现可搜索下拉框扩展
2020/10/23 Javascript
JavaScript 判断对象中是否有某属性的常用方法
2018/06/14 Javascript
node.JS事件机制与events事件模块的使用方法详解
2020/02/06 Javascript
如何通过JS实现转码与解码
2020/02/21 Javascript
原生JS实现萤火虫效果
2020/03/07 Javascript
[03:20]次级联赛厮杀超职业 现超级兵对拆世纪大战
2014/10/30 DOTA
利用Python找出序列中出现最多的元素示例代码
2017/12/08 Python
详解Python3之数据指纹MD5校验与对比
2019/06/11 Python
对Django中内置的User模型实例详解
2019/08/16 Python
python实现单目标、多目标、多尺度、自定义特征的KCF跟踪算法(实例代码)
2020/01/08 Python
mac使用python识别图形验证码功能
2020/01/10 Python
在线课程:Skillshare
2019/04/02 全球购物
交通安全教育制度
2014/02/02 职场文书
军校大学生个人的自我评价
2014/02/17 职场文书
护士毕业实习感言
2014/03/05 职场文书
园林系毕业生求职信
2014/06/23 职场文书
珍惜资源的建议书
2014/08/26 职场文书
2014年庆祝国庆65周年演讲稿
2014/09/21 职场文书
银行客户经理岗位职责
2015/04/09 职场文书
2015法院个人工作总结范文
2015/05/25 职场文书
我是特种兵观后感
2015/06/11 职场文书
2016优秀大学生个人事迹材料范文
2016/03/01 职场文书
个人房屋租赁合同(标准范本)
2019/09/16 职场文书
Java实现斗地主之洗牌发牌
2021/06/14 Java/Android
《异世界四重奏》剧场版6月10日上映 PV视觉图原创角色发表
2022/03/20 日漫
Python安装及建立虚拟环境的完整步骤
2022/06/25 Servers