如果组件文档里面用的是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
可能会这么写
1
2
3
4
5
|
< 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>,于是你可能改成下面这样,但是也会报错
1
2
3
4
5
6
7
8
|
< 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放里面
改成如下
1
2
3
4
5
6
7
|
< a-table > < template v-for = "(item, index) in header" :slot = "item.dataIndex" slot-scope = "text" > < span :key = "index" > {{ text }} </ span > </ template > </ a-table > |
以上解决问题
有个slot没有渲染的问题
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
< 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名字一样了,对的,就是取的临时变量名,修改成不一样的就好了,神奇
1
2
3
4
5
6
7
8
9
10
11
12
13
|
< 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之间相互替换实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/dafadafahao/article/details/106405857