今天工作遇到一个问题:
需求背景:页面中有几个tab,需要根据登录用户的权限控制tab标签的显示与隐藏 。
<el-tabs @tab-click="handleClick" v-model="activeTabName" ref="tabs" > <el-tab-pane label="用户管理" name="first" ref="first" >...</el-tab-pane> <el-tab-pane label="配置管理" name="second" ref="second">...</el-tab-pane> <el-tab-pane label="角色管理" name="third" ref="third">...</el-tab-pane> <el-tab-pane label="定时任务补偿" name="fourth" ref="fourth" >...</el-tab-pane> </el-tabs>
解决方案一:由于前端用的是VUE框架,看到需求,第一个想到的是使用v-show来解决,但是在实际操作中,v-show并没有达到预期效果。
v-show:是通过display:none/block来隐藏/显示<el-tab-pane>标签里边的内容的,但本身并不会隐藏该tab标签。
而且这样做还有一个弊端:如下图,我在“用户管理”添加了v-show=false,此时“用户管理”tab标签下的内容没有显示,
当我点击“配置管理”标签,然后再点“用户管理”标签,猜猜会发生什么?“用户管理”标签下的内容显示了,可是我明明用v-