详解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 相关文章推荐
30分钟就入门的正则表达式基础教程
Feb 25 Javascript
给angular加上动画效遇到的问题总结
Feb 17 Javascript
easyui validatebox验证
Apr 29 Javascript
微信小程序 教程之事件
Oct 18 Javascript
详解自动生成博客目录案例
Dec 09 Javascript
微信小程序左右滑动的实现代码
Dec 15 Javascript
vue.js轮播图组件使用方法详解
Jul 03 Javascript
vue仿element实现分页器效果
Sep 13 Javascript
AngularJS实现的鼠标拖动画矩形框示例【可兼容IE8】
May 17 Javascript
vue elementui el-form rules动态验证的实例代码详解
May 23 Javascript
JavaScript实现留言板案例
Mar 17 Javascript
Vue 数据绑定的原理分析
Nov 16 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伪静态写法附代码
2008/06/20 PHP
php中base_convert()进制数字转换函数实例
2014/11/20 PHP
PHP生成制作验证码的简单实例
2016/06/12 PHP
验证token、回复图文\文本、推送消息的实用微信类php代码
2016/06/28 PHP
PHP实现批量清空删除指定文件夹所有内容的方法
2017/05/30 PHP
PHP基于rabbitmq操作类的生产者和消费者功能示例
2018/06/16 PHP
PHP各种常见经典算法总结【排序、查找、翻转等】
2019/08/05 PHP
奇妙的js
2007/09/24 Javascript
jquery select选中的一个小问题
2009/10/11 Javascript
javascript在事件监听方面的兼容性小结
2010/04/07 Javascript
前端开发过程中浏览器版本的两种判定方法
2013/10/30 Javascript
JavaScript实现的购物车效果可以运用在好多地方
2014/05/09 Javascript
jquery实现键盘左右翻页特效
2015/04/30 Javascript
前端分页功能的实现以及原理(jQuery)
2017/01/22 Javascript
微信小程序自定义toast实现方法详解【附demo源码下载】
2017/11/28 Javascript
基于Nuxt.js项目的服务端性能优化与错误检测(容错处理)
2019/10/23 Javascript
webpack是如何实现模块化加载的方法
2019/11/06 Javascript
JS指定音频audio在某个时间点进行播放
2020/11/28 Javascript
python通过BF算法实现关键词匹配的方法
2015/03/13 Python
收藏整理的一些Python常用方法和技巧
2015/05/18 Python
Python中字符串的常见操作技巧总结
2016/07/28 Python
Python学生成绩管理系统简洁版
2020/04/05 Python
Python+tkinter使用80行代码实现一个计算器实例
2018/01/16 Python
python elasticsearch从创建索引到写入数据的全过程
2019/08/04 Python
django 获取字段最大值,最新的记录操作
2020/08/09 Python
基于python调用jenkins-cli实现快速发布
2020/08/14 Python
大学生优秀的自我评价分享
2013/10/22 职场文书
地球一小时倡议书
2014/04/15 职场文书
大型营销活动计划书
2014/04/28 职场文书
2014大学生中国梦主题教育学习思想汇报
2014/09/10 职场文书
幼儿园小班个人工作总结
2015/02/12 职场文书
居委会工作总结2015
2015/05/18 职场文书
2015年中学团委工作总结
2015/07/22 职场文书
初中军训感言
2015/08/01 职场文书
青年人初次创业的“五不要”
2019/08/23 职场文书
Java 超详细讲解IO操作字节流与字符流
2022/03/25 Java/Android