详解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实现跳转菜单的具体方法
Jul 05 Javascript
Table冻结表头示例代码
Aug 20 Javascript
教你用AngularJS框架一行JS代码实现控件验证效果
Jun 23 Javascript
node.js中的console.dir方法使用说明
Dec 10 Javascript
php结合imgareaselect实现图片裁剪
Jul 05 Javascript
AngularJS控制器详解及示例代码
Aug 16 Javascript
AngularJS使用自定义指令替代ng-repeat的方法
Sep 17 Javascript
js提取中文拼音首字母的封装工具类
Mar 12 Javascript
layui的表单提交以及验证和修改弹框的实例
Sep 09 Javascript
关于layui的下拉搜索框异步加载数据的解决方法
Sep 28 Javascript
jQuery实现提交表单时不提交隐藏div中input的方法
Oct 08 jQuery
Vue替代marquee标签超出宽度文字横向滚动效果
Dec 09 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递归算法和应用方法介绍
2013/04/15 PHP
YII模块实现绑定二级域名的方法
2014/07/09 PHP
php版微信自定义回复功能示例
2016/12/05 PHP
用js实现的页面关键字密度查询代码
2007/12/27 Javascript
JavaScript Konami Code 实现代码
2009/07/29 Javascript
Jquery 插件开发笔记整理
2011/01/17 Javascript
js 通过html()及text()方法获取并设置p标签的显示值
2014/05/14 Javascript
javascript数据结构之双链表插入排序实例详解
2015/11/25 Javascript
基于canvas实现的绚丽圆圈效果完整实例
2016/01/26 Javascript
利用JS提交表单的几种方法和验证(必看篇)
2016/09/17 Javascript
原生node.js案例--前后台交互
2017/02/20 Javascript
关于JavaScript中forEach和each用法浅析
2017/07/27 Javascript
Express使用html模板的详细代码
2017/09/18 Javascript
Vue下滚动到页面底部无限加载数据的示例代码
2018/04/22 Javascript
jQuery实现的页面详情展开收起功能示例
2018/06/11 jQuery
JS实现网站楼层导航效果代码实例
2020/06/16 Javascript
[50:05]VGJ.S vs OG 2018国际邀请赛淘汰赛BO3 第二场 8.22
2018/08/23 DOTA
详解Python中的array数组模块相关使用
2016/07/05 Python
Python selenium 三种等待方式详解(必会)
2016/09/15 Python
Python 模块EasyGui详细介绍
2017/02/19 Python
python+pyqt实现12306图片验证效果
2017/10/25 Python
Python列表删除的三种方法代码分享
2017/10/31 Python
python3 图片referer防盗链的实现方法
2018/03/12 Python
Python实现截取PDF文件中的几页代码实例
2019/03/11 Python
PyTorch学习:动态图和静态图的例子
2020/01/06 Python
python入门之井字棋小游戏
2020/03/05 Python
Python常用编译器原理及特点解析
2020/03/23 Python
keras用auc做metrics以及早停实例
2020/07/02 Python
一文带你掌握Pyecharts地理数据可视化的方法
2021/02/06 Python
CSS3+HTML5+JS 实现一个块的收缩与展开动画效果
2020/11/17 HTML / CSS
Html5+JS实现手机摇一摇功能
2015/04/24 HTML / CSS
渡河少年教学反思
2014/02/12 职场文书
《记金华的双龙洞》教学反思
2014/04/19 职场文书
教师政风行风自查自纠报告
2014/10/21 职场文书
《合作意向书》怎么写?
2019/08/20 职场文书
给numpy.array增加维度的超简单方法
2021/06/02 Python