详解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 相关文章推荐
jQuery第三课 修改元素属性及内容的代码
Mar 14 Javascript
没有document.getElementByName方法
Aug 19 Javascript
JavaScript将字符串转换成字符编码列表的方法
Mar 19 Javascript
详细解读AngularJS中的表单验证编程
Jun 19 Javascript
js变形金刚文字特效代码分享
Aug 20 Javascript
jQuery+CSS3折叠卡片式下拉列表框实现效果
Nov 02 Javascript
getElementById().innerHTML与getElementById().value的区别
Oct 27 Javascript
AngularJS基于ui-route实现深层路由的方法【路由嵌套】
Dec 14 Javascript
vue实现密码显示隐藏切换功能
Feb 23 Javascript
浅谈KOA2 Restful方式路由初探
Mar 14 Javascript
JS中比Switch...Case更优雅的多条件判断写法
Sep 05 Javascript
JS前端可扩展的低代码UI框架Sunmao使用详解
Jul 23 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
经典的星际争霸,满是回忆的BGM
2020/04/09 星际争霸
初学者入门:细述PHP4的核心Zend
2006/09/05 PHP
php过滤HTML标签、属性等正则表达式汇总
2014/09/22 PHP
WordPress中获取页面链接和标题的相关PHP函数用法解析
2015/12/17 PHP
php使用curl下载指定大小的文件实例代码
2017/09/30 PHP
在Javascript中为String对象添加trim,ltrim,rtrim方法
2006/09/22 Javascript
自适应高度框架 ----属个人收藏内容
2007/01/22 Javascript
js中判断文本框是否为空的两种方法
2011/07/31 Javascript
jQuery实现可拖动的浮动层完整代码
2013/05/27 Javascript
Javascript Objects详解
2014/09/04 Javascript
详细解读AngularJS中的表单验证编程
2015/06/19 Javascript
浅谈JavaScript的Polymer框架中的事件绑定
2015/07/29 Javascript
JS实现的简洁纵向滑动菜单(滑动门)效果
2015/10/19 Javascript
理解javascript正则表达式
2016/03/08 Javascript
jQuery mobile在页面加载时添加加载中效果 document.ready 和window.onload执行顺序比较
2016/07/14 Javascript
jquery实现输入框实时输入触发事件代码
2016/12/21 Javascript
jQuery EasyUI 页面加载等待及页面等待层
2017/02/06 Javascript
vue 请求后台数据的实例代码
2017/06/22 Javascript
老生常谈javascript的面向对象思想
2017/08/22 Javascript
JavaScript实现图片拖曳效果
2017/09/08 Javascript
vue-cli常用设置总结
2018/02/24 Javascript
D3.js实现简洁实用的动态仪表盘的示例
2018/04/04 Javascript
详解vue-cli 3.0 build包太大导致首屏过长的解决方案
2018/11/10 Javascript
JavaScript的垃圾回收机制与内存管理
2020/08/06 Javascript
javascript实现随机抽奖功能
2020/12/30 Javascript
python3模块smtplib实现发送邮件功能
2018/05/22 Python
python输出100以内的质数与合数实例代码
2018/07/08 Python
python生成lmdb格式的文件实例
2018/11/08 Python
利用nohup来开启python文件的方法
2019/01/14 Python
Python机器学习算法库scikit-learn学习之决策树实现方法详解
2019/07/04 Python
基于Python数据分析之pandas统计分析
2020/03/03 Python
Python环境使用OpenCV检测人脸实现教程
2020/10/19 Python
利用Bootstrap实现漂亮简洁的CSS3价格表实例源码
2017/03/02 HTML / CSS
Bobbi Brown芭比波朗美国官网:化妆师专业彩妆保养品品牌
2016/08/18 全球购物
司法廉洁教育心得体会
2016/01/20 职场文书
SQL Server中使用表变量和临时表
2022/05/20 SQL Server