vue實(shí)現(xiàn)底部菜單功能
具體代碼如下所示:
<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;//因?yàn)檫@個(gè)切換選項(xiàng)卡就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){//因?yàn)檫@里的path是隨著選項(xiàng)卡切換改變的。所以要寫(xiě)成動(dòng)態(tài)的。
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>

我的幾個(gè)圖標(biāo)是這樣的。
最終的效果點(diǎn)擊那個(gè)那個(gè)就變成藍(lán)色的。并且進(jìn)入子頁(yè)面再切出來(lái)他還是藍(lán)色的。

總結(jié)
以上所述是小編給大家介紹的vue實(shí)現(xiàn)底部菜單功能,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- 用 Vue.js 遞歸組件實(shí)現(xiàn)可折疊的樹(shù)形菜單(demo)
- 詳解Vue用自定義指令完成一個(gè)下拉菜單(select組件)
- vue.js 左側(cè)二級(jí)菜單顯示與隱藏切換的實(shí)例代碼
- Vue.js手風(fēng)琴菜單組件開(kāi)發(fā)實(shí)例
- vue2.0實(shí)現(xiàn)導(dǎo)航菜單切換效果
- Vue組件tree實(shí)現(xiàn)樹(shù)形菜單
- Vue2組件tree實(shí)現(xiàn)無(wú)限級(jí)樹(shù)形菜單
- Vue.js 遞歸組件實(shí)現(xiàn)樹(shù)形菜單(實(shí)例分享)
- Vue.js組件tree實(shí)現(xiàn)無(wú)限級(jí)樹(shù)形菜單
相關(guān)文章
Vue中select下拉框的默認(rèn)選中項(xiàng)的三種情況解讀
這篇文章主要介紹了Vue中select下拉框的默認(rèn)選中項(xiàng)的三種情況解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05
Vue語(yǔ)法和標(biāo)簽的入門(mén)使用教程
Vue是一套用于構(gòu)建用戶界面的漸進(jìn)式框架,下面這篇文章主要給大家介紹了關(guān)于Vue語(yǔ)法和標(biāo)簽使用的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08
Element中select多數(shù)據(jù)加載優(yōu)化的實(shí)現(xiàn)
本文主要介紹了Element中select多數(shù)據(jù)加載優(yōu)化的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
Vue3實(shí)現(xiàn)SSE(Server-Sent?Events)連接
SSE?是一種允許服務(wù)器向?yàn)g覽器推送事件的技術(shù),這篇文章主要為大家詳細(xì)介紹了如何通過(guò)vue3實(shí)現(xiàn)SSE(Server-Sent?Events)連接,有需要的小伙伴可以了解下2024-10-10
Vue路由跳轉(zhuǎn)傳參或打開(kāi)新頁(yè)面跳轉(zhuǎn)的方法總結(jié)
這篇文章主要給大家介紹了關(guān)于Vue路由跳轉(zhuǎn)傳參或打開(kāi)新頁(yè)面跳轉(zhuǎn)的相關(guān)資料,在使用Vue.js開(kāi)發(fā)單頁(yè)面應(yīng)用時(shí)常常會(huì)遇到路由跳轉(zhuǎn)傳參的需求,需要的朋友可以參考下2023-07-07
詳解vue-router 2.0 常用基礎(chǔ)知識(shí)點(diǎn)之router.push()
本篇文章主要介紹了vue-router 2.0 常用基礎(chǔ)知識(shí)點(diǎn)之router.push(),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-05-05
vue components 動(dòng)態(tài)組件詳解
這篇文章主要介紹了vue components 動(dòng)態(tài)組件,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-11-11

