v-slot和slot、slot-scope之间相互替换实例


Posted in Javascript onSeptember 04, 2020

如果组件文档里面用的是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之间相互替换实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript 可以拖动的DIV(二)
Jun 26 Javascript
浅谈javascript六种数据类型以及特殊注意点
Dec 20 Javascript
jQuery绑定事件监听bind和移除事件监听unbind用法实例详解
Jan 19 Javascript
简单的js表格操作
Sep 24 Javascript
给easyui的datebox控件添加清空按钮的实现方法
Nov 09 Javascript
在javaScript中检测数据类型的几种方式小结
Mar 04 Javascript
Angular中的$watch方法详解
Sep 18 Javascript
vue实现微信分享朋友圈,发送朋友的示例讲解
Feb 10 Javascript
详解ESLint在Vue中的使用小结
Oct 15 Javascript
webstorm中配置Eslint的两种方式及差异比较详解
Oct 19 Javascript
Vue注册组件命名时不能用大写的原因浅析
Apr 25 Javascript
layui 阻止图片上传的实例(before方法)
Sep 26 Javascript
Vue插槽_特殊特性slot,slot-scope与指令v-slot说明
Sep 04 #Javascript
解决vue scoped scss 无效的问题
Sep 04 #Javascript
vue-admin-template配置快捷导航的代码(标签导航栏)
Sep 04 #Javascript
基于vue中的scoped坑点解说
Sep 04 #Javascript
VUE : vue-cli中去掉路由中的井号#操作
Sep 04 #Javascript
Vue利用localStorage本地缓存使页面刷新验证码不清零功能的实现
Sep 04 #Javascript
vue-cli3中配置alias和打包加hash值操作
Sep 04 #Javascript
You might like
smarty简单应用实例
2015/11/03 PHP
PHP基于单例模式实现的mysql类
2016/01/09 PHP
jQuery的实现原理的模拟代码 -3 事件处理
2010/08/03 Javascript
JavaScript中的this实例分析
2011/04/28 Javascript
创建公共调用 jQuery Ajax 带返回值
2012/08/01 Javascript
让ie6也支持websocket采用flash封装实现
2013/02/18 Javascript
jquery设置元素的readonly和disabled的写法
2013/09/22 Javascript
利用jq让你的div居中的好方法分享
2013/11/21 Javascript
js获取滚动距离的方法
2015/05/30 Javascript
浅谈关于JavaScript API设计的一些建议和准则
2015/06/24 Javascript
使用NodeJs 开发微信公众号(三)微信事件交互实例
2016/03/02 NodeJs
jquery pagination分页插件使用详解(后台struts2)
2017/01/22 Javascript
微信小程序图片横向左右滑动案例
2017/05/19 Javascript
微信小程序之多文件下载的简单封装示例
2018/01/29 Javascript
红黑树的插入详解及Javascript实现方法示例
2018/03/26 Javascript
使用vue-router为每个路由配置各自的title
2018/07/30 Javascript
如何基于vue-cli3.0构建功能完善的移动端架子
2019/04/24 Javascript
基于jQuery拖拽事件的封装
2020/11/29 jQuery
JavaScript实现点击切换功能
2021/01/27 Javascript
TensorFlow高效读取数据的方法示例
2018/02/06 Python
Python基于递归实现电话号码映射功能示例
2018/04/13 Python
在IPython中执行Python程序文件的示例
2018/11/01 Python
Python3+Requests+Excel完整接口自动化测试框架的实现
2019/10/11 Python
Python3.7基于hashlib和Crypto实现加签验签功能(实例代码)
2019/12/04 Python
Python任务调度利器之APScheduler详解
2020/04/02 Python
详解Java中一维、二维数组在内存中的结构
2021/02/11 Python
使用css3匹配手机屏幕横竖状态
2014/01/27 HTML / CSS
HTML5在IE10、火狐下中文乱码问题的解决方法
2013/11/18 HTML / CSS
日本无添加化妆品:HABA
2016/08/18 全球购物
英国二手iPhone、音乐、电影和游戏商店:musicMagpie
2018/10/26 全球购物
简述DNS进行域名解析的过程
2013/12/02 面试题
境外导游求职信
2014/02/27 职场文书
人事主管岗位职责
2015/02/04 职场文书
Python使用Kubernetes API访问集群
2021/05/30 Python
教你怎么用Python操作MySql数据库
2021/05/31 Python
Python开发五子棋小游戏
2022/04/28 Python