vue實現(xiàn)底部菜單功能
更新時間:2018年07月24日 15:33:56 作者:夏天想
本文通過實例代碼給大家介紹了vue實現(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;//因為這個切換選項卡就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是隨著選項卡切換改變的。所以要寫成動態(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>

我的幾個圖標是這樣的。
最終的效果點擊那個那個就變成藍色的。并且進入子頁面再切出來他還是藍色的。

總結(jié)
以上所述是小編給大家介紹的vue實現(xiàn)底部菜單功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Vue中對watch的理解(關(guān)鍵是immediate和deep屬性)
watch偵聽器,是Vue實例的一個屬性,是用來響應(yīng)數(shù)據(jù)的變化,需要在數(shù)據(jù)變化時執(zhí)行異步或開銷較大的操作時,這個方式是最有用的,這篇文章主要介紹了Vue中對watch的理解,需要的朋友可以參考下2022-11-11
Vue監(jiān)聽事件實現(xiàn)計數(shù)點擊依次增加的方法
今天小編就為大家分享一篇Vue監(jiān)聽事件實現(xiàn)計數(shù)點擊依次增加的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09
Vue實施重新發(fā)布和軟件熱更新的經(jīng)驗分享
在Web應(yīng)用的開發(fā)周期中,版本管理和軟件熱更新是一個不可或缺的話題,隨著Vue.js框架的流行,越來越多的應(yīng)用程序選擇使用Vue來構(gòu)建前端,本文將探討在Vue應(yīng)用中實施重新發(fā)布和熱更新的最佳實踐,需要的朋友可以參考下2024-09-09
解決Vue使用百度地圖BMapGL內(nèi)存泄漏問題?Out?of?Memory
這篇文章主要介紹了解決Vue使用百度地圖BMapGL內(nèi)存泄漏問題?Out?of?Memory,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-12-12

