时间:2021-05-26
如果组件文档里面用的是v-slot,而你用的是vue2.6之前的版本,则需要替换v-slot:所以有两种替换方式,注意看两块v-slot有啥不同,你就知道你该怎么用slot-scope和slot来替换文档中的v-slot了
v-slot使用方式1:
<template v-slot:operate="{ row }"><template>
则可替换为:
<template slot="operate" slot-scope="{ row }"></template>
v-slot使用方式2:
<template v-slot="{ row }"><template>
则可替换为:
<template slot-scope="row"></template>
先记录后期再完善,赶项目去了
补充知识:V-for and slot-scoped报错问题
此场景是为了用v-for动态渲染表格的slot
可能会这么写
<a-table> <span v-for="(item, index) in header" :key="index" :slot="item.dataIndex" slot-scope="text" > {{ text }} </span></a-table>但是这样子会报错,因为v-for和slot-scope在同一级
Ambiguous combined usage of slot-scope and v-for on (v-for takes higher priority). Use a wrapper < template> for the scoped slot to make it clearer.
提示在外边包一层< template>,于是你可能改成下面这样,但是也会报错
<a-table> <template v-for="(item, index) in header" :key="index"> <span :slot="item.dataIndex" slot-scope="text" > {{ text }} </span> </template></a-table>< template> cannot be keyed. Place the key on real elements instead.提示< template>template不能写key, 即使没有这个错,表格数据也不会渲染出来,因为这一层没有slot,应该说slot应该是放最外面,同时把:key放里面
改成如下
<a-table> <template v-for="(item, index) in header" :slot="item.dataIndex" slot-scope="text"> <span :key="index"> {{ text }} </span> </template></a-table>以上解决问题
有个slot没有渲染的问题
<template v-for="(slotname, idx) in ['status', 'sub_account_status']" :slot="slotname" slot-scope="text" > <span :key="idx"> <a-tag v-if="text === '正常'" color="blue">{{ text }}</a-tag> <a-tag v-else color="red">{{ text }}</a-tag> </span> </template> <!-- 包名称、关联账号 --> <template v-for="(slotname, idx) in ['app_name', 'roles']" :slot="slotname" slot-scope="text" > <span :key="idx"> <a-tooltip placement="top" > <template slot="title"> <span v-for="(item, index) in text" :key="index">{{ item }}<br/></span> </template> <div class="tableHidden"> <a-tag v-for="(item, index) in text" :key="index">{{ item }} </a-tag> </div> </a-tooltip> </span> </template>好像是因为2个v-for="(slotname, idx)"里的slotname名字一样了,对的,就是取的临时变量名,修改成不一样的就好了,神奇
<template v-for="(name, idx) in ['status', 'sub_account_status']" :slot="name" slot-scope="text" > // 上面那个name <span :key="idx"> 。。。 </span> </template> <!-- 包名称、关联账号 --> <template v-for="(slotname, idx) in ['app_name', 'roles']" :slot="slotname" slot-scope="text" > <span :key="idx"> 。。。 </a-tooltip> </span> </template>以上这篇v-slot和slot、slot-scope之间相互替换实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在2.6.0中,我们为具名插槽和作用域插槽引入了一个新的统一的语法(即v-slot指令)。它取代了slot和slot-scope这两个目前已被废弃但未被移除且仍
1、slot作用/概念:预先将将来要使用的内容进行保留;2、具名插槽:给slot起个名字3、slot、slot-scope已经被废弃推荐使用vue2.6.0中的
在vue2.5.0+中slot-scope替代了scopetemplate的使用情形为,我们已经封装好一个组建,预留了插槽,使用的插槽首先我们的创建一个组建组建
下面给大家介绍Vue组件中slot的用法主要是让组件的可扩展性更强。1.使用匿名slot2.给slot加个名字如果不在有slot的组件里加入任何标签,slot什
前言本文将介绍vue2.0中的组件的继承与扩展,主要分享slot、mixins/extends和extend的用法。一、slot1.默认插槽和匿名插槽slot用