vue 路由导航样式active始终选中

在vue项目中会存在各种各样的导航,头部导航栏,侧边栏导航

例如,有时候,在头部导航栏点击“消息中心”跳转到页面的时候,往往会变成这种情况

但是这里还出现了一个侧导航栏,所以出现了两种状况

状况1:消息中心的背景颜色不见了

理想状态:

实际效果:

解决办法:

在css样式中,给.router-link-exact-active加上颜色即可

 

 状况2:应该默认选中侧栏的第一个,但是此时“消息中心”中的选中样式消失了,如下图

理想状态是点击侧栏切换的时候,顶部的样式不受影响

解决办法:

修改头部导航栏样式:

原来样式:

<router-link v-for="(item,index) in list" :key="item.value" :to="{path:item.path}" @click.native="changeBgc(index)" class="topbar-item">
  {{item.label}}
</router-link>
 
修改后:
给代码加上 :class="{'router-link-exact-active':ind == index}
即改为:
<router-link v-for="(item,index) in list" :key="item.value" :to="{path:item.path}" :class="{'router-link-exact-active':ind == index} @click.native="changeBgc(index)" class="topbar-item">
  {{item.label}}
</router-link>
然后即可达到我们想要的状态,点击侧栏切换的时候导航样式不受影响

 

posted on 2018-02-26 11:12  ss要更加努力  阅读(12341)  评论(1)    收藏  举报

导航