详解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仿PS里的羽化效果代码
Dec 20 Javascript
jquery应该如何来设置改变按钮input的onclick事件
Dec 10 Javascript
使用非html5实现js板连连看游戏示例代码
Sep 22 Javascript
jQuery中appendTo()方法用法实例
Jan 08 Javascript
jQuery实现手机号码输入提示功能实例
Apr 30 Javascript
Javascript的表单验证-揭开正则表达式的面纱
Mar 18 Javascript
Bootstrap表格和栅格分页实例详解
May 20 Javascript
javascript验证内容为数字以及长度为10的简单实例
Aug 20 Javascript
基于chosen插件实现人员选择树搜索自动筛选功能
Sep 24 Javascript
jquery 仿锚点跳转到页面指定位置的实例
Feb 14 Javascript
php中and 和 &amp;&amp;出坑指南
Jul 13 Javascript
JavaScript实现淘宝京东6位数字支付密码效果
Aug 18 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 heredoc和phpwind的模板技术使用方法小结
2008/03/28 PHP
php实现网页缓存的工具类分享
2015/07/14 PHP
老生常谈PHP面向对象之解释器模式
2017/05/17 PHP
Laravel监听数据库访问,打印SQL的例子
2019/10/24 PHP
javascript 操作cookies及正确使用cookies的属性
2009/10/15 Javascript
JavaScript Event学习第六章 事件的访问
2010/02/07 Javascript
利用谷歌地图API获取点与点的距离的js代码
2012/10/11 Javascript
JS判断字符串包含的方法
2015/05/05 Javascript
jquery实现手机号码选号的方法
2015/07/31 Javascript
JavaScript实现身份证验证代码
2016/02/17 Javascript
JS限制条件补全问题实例分析
2016/12/16 Javascript
BootStrap表单验证实例代码
2017/01/13 Javascript
NodeJS遍历文件生产文件列表功能示例
2017/01/22 NodeJs
setTimeout学习小结
2017/02/08 Javascript
JavaScript实现的冒泡排序法及统计相邻数交换次数示例
2017/04/26 Javascript
JavaScript实现QQ聊天消息展示和评论提交功能
2017/05/22 Javascript
使用 Node.js 模拟滑动拼图验证码操作的示例代码
2017/11/02 Javascript
详解如何实现一个简单的 vuex
2018/02/10 Javascript
vue无限轮播插件代码实例
2019/05/10 Javascript
NUXT SSR初级入门笔记(小结)
2019/12/16 Javascript
jQuery实现的解析本地 XML 文档操作示例
2020/04/30 jQuery
vue 限制input只能输入正数的操作
2020/08/05 Javascript
[03:24]2014DOTA2国际邀请赛 神秘商店生意火爆
2014/07/18 DOTA
selenium获取当前页面的url、源码、title的方法
2019/06/12 Python
解决python 3 urllib 没有 urlencode 属性的问题
2019/08/22 Python
Python 调用 Windows API COM 新法
2019/08/22 Python
查看keras的默认backend实现方式
2020/06/19 Python
Smashbox英国官网:美国知名彩妆品牌
2017/11/13 全球购物
英国日常交易网站:Wowcher
2018/09/04 全球购物
中国专业的音频分享平台:喜马拉雅
2019/05/24 全球购物
安踏官方商城:anta.cn
2019/12/16 全球购物
英国户外服装、鞋类和设备的领先零售商:Millets
2020/10/12 全球购物
英语系毕业生自荐信
2013/10/31 职场文书
青年教师培训方案
2014/02/06 职场文书
车间机修工岗位职责
2014/02/28 职场文书
关于运动会的口号
2014/06/07 职场文书