vue 开发系列(十) VUE 作用域插槽
使用场景
官方解释,有时让插槽内容能够访问子组件中才有的数据是很有用的。比如我们在使用ant-design-vue 的表格控件时。
<a-table-column title="注释" dataIndex="comment" >
<template slot-scope="text, record">
<rx-textbox v-model="record.comment" ></rx-textbox>
</template>
</a-table-column>
这里从控件传递数据到父组件,我们在使用组件的时候,可以根据我们的需要显示需要的效果,表格控件并不需要关心如何实现数据的展示。
我们怎么理解这个作用域插槽呢?
下面我们举一个简单的例子还说明这个问题。
实现过程
编写子组件
<template>
<div class="child">
<h3>这里是子组件</h3>
<slot name="demo" :text="account" :record="user"></slot>
</div>
</template> <script>
export default {
name:"child",
data(){
return {
user: ['张三','李四',"王五"],
account:"ray"
}
}
}
</script>
这里有两个知识点。
1.具名插槽
2.传递数据
把帐号和记录数据传递出去。
父组件代码
<template>
<div class="father">
<child>
<template slot="demo" slot-scope="{text,record}">
{{text}}
<div v-for="item in record" :key="item">{{item}}</div>
</template>
</child>
<child>
<template v-slot:demo="{text,record}">
{{text}}
<div v-for="item in record" :key="item">{{item}}</div>
</template>
</child>
</div>
</template> <script>
import Vue from 'vue' import ChildSlot from '@/components/ChildSlot.vue' Vue.component(ChildSlot.name, ChildSlot); export default {
name: 'HelloWorld', }
</script>
在这里例子中我展示了两种写法:
slot="demo" slot-scope="{text,record}"
这种写法 其实不推荐使用的,这个在2.6之后是需要废弃的。
<template  v-slot:demo="{text,record}">
推荐写法使用 v-slot 指令来实现。

最终显示效果其实是一样的。
vue 开发系列(十) VUE 作用域插槽的更多相关文章
- vue 开发系列(九) VUE 动态组件的应用
		
业务场景 我们在开发表单的过程中会遇到这样的问题,我们选择一个控件进行配置,控件有很多中类型,比如文本框,下来框等,这些配置都不同,因此需要不同的配置组件来实现. 较常规的方法是使用v-if 来实现, ...
 - S3C2416裸机开发系列十六_sd卡驱动实现
		
S3C2416裸机开发系列十六 sd卡驱动实现 象棋小子 1048272975 SD卡(Secure Digital Memory Card)具有体积小.容量大.传输数据快.可插拔.安全性好等长 ...
 - vue 开发系列(一) vue 开发环境搭建
		
概要 目前前端开发技术越来越像后台开发了,有一站式的解决方案. 1.JS包的依赖管理像MAVEN. 2.JS代码编译打包. 3.组件式的开发. vue 是一个前端的一站式的前端解决方案,从项目的初始化 ...
 - 【Qt编程】基于Qt的词典开发系列<十五>html特殊字符及正则表达式
		
1.html特殊字符的显示 我们知道html语言和C语言一样也有一些特殊字符,它们是不能正常显示的,必须经过转义,在网上可以查到如何显示这些字符,如下图所示: 上图给了最常用的特殊字符的显示,下面我们 ...
 - BizTalk开发系列(十八) 使用信封拆分数据库消息
		
之前写了一篇的<BizTalk开发系列(十七) 信封架构(Envelop)> 是关于信封架构及其拆装原理的,都是理论性的内容.信封在BizTalk开发过程中最常用的应该是在读取SQL Se ...
 - 【Qt编程】基于Qt的词典开发系列<十>--国际音标的显示
		
在年前的一篇文章中,我提到要学习Qt.于是在这学期看了一个月的qt.现在大致对qt有了一些了解.但是现在导师又把我调到了android应用开发平台,所以说qt的学习要搁置了.本打算这学期做一个单词查询 ...
 - 【Qt编程】基于Qt的词典开发系列<十二>调用讲述人
		
我们知道,win7系统自带有讲述人,即可以机器读出当前内容,具体可以将电脑锁定,然后点击左下角的按钮即可.之前在用Matlab写扫雷游戏的时候,也曾经调用过讲述人来进行游戏的语音提示.具体的Matla ...
 - 【Qt编程】基于Qt的词典开发系列<十四>自动补全功能
		
最近写了一个查单词的类似有道词典的软件,里面就有一个自动补全功能(即当你输入一个字母时,就会出现几个候选项).这个自动补全功能十分常见,百度搜索关键词时就会出现.不过它们这些补全功能都是与你输入的进行 ...
 - vue开发环境及vue相关
		
一.安装node.js Vue项目通常通过webpack工具来构建,而webpack命令的执行是依赖node.js的环境的,所以首先要安装node.js. 二.安装cnpm cnpm是淘宝对npm的镜 ...
 
随机推荐
- Shell命令-网络操作之基础之ping、route
			
文件及内容处理 - ping.route 1. ping:测试主机之间网络的连通性 ping命令的功能说明 ping 命令用于检测主机.执行 ping 指令会使用 ICMP 传输协议,发出要求回应的信 ...
 - Python文件读取中:f.seek(0)和f.seek(0,0)有什么区别
			
file.seek()方法标准格式是:seek(offset,whence=0)offset:开始的偏移量,也就是代表需要移动偏移的字节数whence:给offset参数一个定义,表示要从哪个位置开始 ...
 - 【2019.8.7 慈溪模拟赛 T2】环上随机点(ran)(自然算法)
			
简单声明 我是蒟蒻不会推式子... 所以我用的是乱搞做法... 大自然的选择 这里我用的乱搞做法被闪指导赐名为"自然算法",对于这种输入信息很少的概率题一般都很适用. 比如此题,对 ...
 - 【CodeForces】CodeForcesRound576 Div1 解题报告
			
点此进入比赛 \(A\):MP3(点此看题面) 大致题意: 让你选择一个值域区间\([L,R]\),使得序列中满足\(L\le a_i\le R\)的数的种类数不超过\(2^{\lfloor\frac ...
 - select使用css居右对齐
			
select{ direction: rtl; } 下面的方法无效 select{ text-align: right; }
 - 阿里云cdn缓存设置技巧,不同文件结尾用不同的缓存时间
			
https://edu.aliyun.com/lesson_130_1505?spm=5176.10731542.0.0.2ed37dbf42YL6U#_1505
 - 使用nexus搭建maven仓库(maven 本地私服)
			
我们在使用maven的时候,对于项目所依赖的jar包,maven默认会在中央仓库下载jar包,到本地的磁盘目录(如果没有配置则是用户目录下/.m2/repository文件夹下).如果公司内部搭了一个 ...
 - spring cloud启动zipkin,报错maven依赖jar包冲突 Class path contains multiple SLF4J bindings
			
项目启动报错: Connected to the target VM, address: '127.0.0.1:59412', transport: 'socket' SLF4J: Class pat ...
 - Docker安装使用以及mlsql的docker安装使用说明
			
1.检查内核版本,必须是3.10及以上 uname -r 2.安装 yum -y install docker #1.启动 docker systemctl start docker #1.1.验 ...
 - 博云 x 某农商行 | 银行信息化运维系统升级的最佳实践
			
随着银行新一代信息化运维系统建设的推进,应用系统更新换代速度明显提升.数字化转型的发展对银行业务需求的敏捷性提出了越来越高的要求,促进敏捷开发和资源敏捷部署成为大势所趋. 背景 江苏某农村商业银行成立 ...