什么是scoped slots
A scoped slot is a special type of slot that functions as a reusable template (that can be passed data to) instead of already-rendered-elements.
上面是官方的定义。
作用域插槽(Scoped Slots)是vue.js中一个非常有用的特性,它可以使组件更加通用和复用。唯一的问题是理解起来比较困难。试图去让你理解父与子作用域的交织关系,像解决一道数学难题。
简单点说slot就是插槽,它是可以被替换掉的,替换它的内容是可以拿到当前组件的上下文的
(为了简单起见,以下例子以模板为主)
举个简单的例子
//button.vue <template> <button class="btn"> <slot></slot> //相当于是占位 </button> </template> <script> export default { } </script>
//app.vue <template> <div id="app"> <Button>Buton with text</Button> <Button> <i class="fa fa-copy"></i>//这里取代了slot的位置 </Button> <Button> <i class="fa fa-user"></i>Profile </Button> </div> </template> <script> import Button from './components/Button.vue' export default { name: 'app', components: { Button } } </script>
slot其实就是一个占位,button.vue的slot位置会被app.vue里面的替换了。
复杂例子1:slot内的东西可以获取父组件的上下文信息
//list.vue <template> <div> <slot v-for="item in items" :item="item">//这里是slot的占位 </slot> </div> </template>
//app.vue <template> <div id="app"> <List :items="listItems"> <div slot-scope="row" class="list-item1">//这里可以获取到item,item原本是属于List组件内部的。也就是说slot获取了父组件的上下文。 {{row.item.text}} </div> </List> </div> </template>
解释见上面代码注释。注意一点的是slot-scope=”row” 这里的名字(row)是可以任意取的。
named slots
可以直接放到普通标签上面,可以放template标签上
slot里面的作用域是普通标签或者template是一致的。不能访问父组件的作用域。
复杂例子2:slot里面是可以放东西的,是默认的模板,可被替换。
//table.vue <template> <table class="table"> <thead> <slot name="columns">//这里定义了一个slot,名字叫columns,也就是说这里的内容是可以被替换掉的 <th v-for="column in columns"> {{column}} </th> </slot> </thead> <tbody> <tr v-for="item in data"> <slot :row="item">//这里slot有一个prop是row <td v-for="column in columns" v-if="hasValue(item, column)"> {{itemValue(item, column)}} </td> </slot> </tr> </tbody> </table> </template>
//app.vue <template> <div id="app"> <CustomTable :data="tableData" :columns="tableColumns"> </CustomTable> <div class="table-separator"></div> <CustomTable :data="tableData"> <template slot="columns">//这里有一个slot="columns",意思是替换table.vue里面名字叫columns的slot <th>Title</th> <th> <i class="fa fa-images"></i> Image </th> <th class="actions-row"> <i class="fab fa-vuejs vue-icon"></i> Actions </th> </template> <template slot-scope="{row}">//这里替换table.vue里面slot为row的内部内容 <td class="bold-row"> {{row.title}} </td> <td class="img-row"> <img :src="/UploadFiles/2021-04-02/row.img">以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]