用ElementPlus开发el-tab结合router-view调用组件时需要注意多次渲染的问题

最近在用vue3+elementPlus开发后台界面,用到右侧el-tab这个组件结合router-view实现调用,刚在逛csdn的时候发现一个大佬说如果把router-view放在el-tab-pane下会导致多次渲染,我想还有这事?赶紧测试一下。。。果然,大佬还是大佬。

原代码及渲染次数

<el-tabs v-model="activeTab" type="card" closable @tab-remove="removeTab">
  <el-tab-pane v-for="tab in tabs" :key="tab._id" :label="tab.title" :name="tab._id">
    <router-view></router-view>
  </el-tab-pane>
</el-tabs>

点击三个菜单

在这里插入图片描述

注意一下左侧的次数,出乎意料啊。

在这里插入图片描述

修改代码及渲染次数

router-view扔出去

<el-tabs v-model="activeTab" type="card" closable @tab-remove="removeTab">
  <el-tab-pane v-for="tab in tabs" :key="tab._id" :label="tab.title" :name="tab._id">
  </el-tab-pane>
</el-tabs>
<router-view></router-view>

在这里插入图片描述
果然干净了!

同时还解决了我另一个问题:
之前默认打开页面时要显示首页,代码写好了却一直没实现,我想是个小问题就没去管,结果刚才把router-view拿出el-tab-pane后就好了~~看来就是他自说自话把我要显示的给覆盖渲染掉了。

【vue】elementUi 里面的tabs标签页使用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值