时间:2021-05-26
具体代码如下所示:
<template> <div class="mui-row"> <div class="mui-col-xs-12 mui-row nav"> <div class="mui-col-xs-4" @tap="tab1=1;tab2=1;tab3=1"> <router-link to="/recommend" ><img :src="'img/tabIcon/tab1'+tab1+'.png'" @tap="tab1=1;tab2=1;tab3=1"/><span class="mui-tab-label" @tap="tab1=1;tab2=1;tab3=1">{{"推荐好课" | title}}</span></router-link> </div> <div class="mui-col-xs-4" @tap="tab2=2;tab1=2;tab3=1"> <router-link :to="{path: '/Broadcast/' +(tabNum=tabNum==undefined?0:tabNum)}"><img :src="'img/tabIcon/tab2'+tab2+'.png'" @tap="tab2=2;tab1=2;tab3=1"/><span class="mui-tab-label" @tap="tab2=2;tab1=2;tab3=1">{{"师道直播" | title}}</span></router-link> </div> <div class="mui-col-xs-4" @tap="tab3=2;tab1=2;tab2=1"> <router-link to="/my"><img :src="'img/tabIcon/tab3'+tab3+'.png'" @tap="tab3=2;tab1=2;tab2=1"/><span class="mui-tab-label" @tap="tab3=2;tab1=2;tab2=1">{{"我" | title}}</span></router-link> </div> </div> </div> </template><style scoped> .mui-row { background: #FFF; border-top:1px solid #F5F5F5; } .mui-col-xs-12 .mui-col-xs-4 { text-align: center; height: 50px; } img{position:relative; top:0px; width: 30px; height: 30px; padding-top: 0; padding-bottom: 0; } .mui-tab-label{ font-size: 11px; display: block; overflow: hidden; text-overflow: ellipsis; margin-top: -7px; } a{color:#b9b5b5;} .mui-bar{ -webkit-box-shadow: 0 0 1px rgba(222, 219, 219, 0.85); box-shadow: 0 0 1px rgba(222, 219, 219, 0.85); } .mui-row .router-link-exact-active.router-link-active{ color:#3FCDFF; } .mui-col-xs-12 .mui-col-xs-4 a{height: 50px; display: inline-block; width: 100%;}</style><script> export default { created() { this.$route.params.tabNum=0; }, mounted() { if(this.$route.params.tabNum!='undefined'){ this.tabNum=this.$route.params.tabNum;//因为这个切换选项卡就path改变了 } else{ this.tabNum=0; } if(this.$route.path=='/my'){ this.tab3=2;this.tab1=2;this.tab2=1 } else if(this.$route.path=='/Broadcast/'+this.tabNum){//因为这里的path是随着选项卡切换改变的。所以要写成动态的。 this.tab2=2;this.tab1=2;this.tab3=1 }else{ this.tab1=1;this.tab2=1;this.tab3=1 } }, beforeRouteEnter(to, from, next) { // console.log(to) // if (to.params.db == null) { // return next({ name: "", params: { id: to.params.id } }); // } // next(); }, components: {}, data() { return { tabNum:0, tab1:1, tab2:1, tab3:1, } }, methods: { }, watch:{ "$route.params"(tab){ // this.tabNum=this.$route.params.tabNum; }, } }</script>我的几个图标是这样的。
最终的效果点击那个那个就变成蓝色的。并且进入子页面再切出来他还是蓝色的。
总结
以上所述是小编给大家介绍的vue实现底部菜单功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
下面一段代码给大家介绍vue实现的树形菜单功能,具体代码如下所示:vue*{color:#585858;}#app{min-height:650px;}#app
学习了AndroidPopupWindow的使用技巧和【AndroidUI设计与开发】7.底部菜单栏(四)PopupWindow实现显示仿腾讯新闻底部弹出菜单,
前言现在大部分App底部都有一个菜单,实现这个功能也有好多办法:-TabHost+Fragment-RadioGroup+Fragment-FragmentTa
本文实例为大家分享了Android实现底部弹出按钮菜单的具体代码,在Android实现底部缓慢弹出菜单的升级,供大家参考,具体内容如下只贴出关键代码caseR.
本文实例讲述了微信小程序实现action-sheet弹出底部菜单功能。分享给大家供大家参考,具体如下:1、效果展示2、关键代码①index.wxml弹出acti