vue 中使用element-ui的menu选中项高亮的问题

怎甘沉沦 提交于 2019-11-30 16:16:14

  使用element中的menu组件时,根据官方文档,可以设置给el-menu设置route属性为:true,给el-menu-item设置index的值为路径,就可以实现点击导航跳转到指定路由。

  样做虽然能实现跳转,并且通过父页面点击到其他页面的时候,选中的仍然是当前导航,比如导航列表:a、b,从b可以跳转c,跳转到c时,导航栏选中的是b,这样是符合我们的要求的,但是,若刷新浏览器,则此时页面还停留在c的页面,导航却选中到a了(假设默认的选中项设置为a)。

     为了解决这个问题,百度了很多,也有解决办法,那就是将default-active属性设置为:$route.path,这样页面重新渲染时就会选中当前的路由了。可是,解决了刷新的问题,前面说到的从b跳转到c,此时因为路由变了,找不到与index匹配的路由了,导航栏就不会再高亮了。

  仔细读element官网上的menu属性,发现还有一个属性没用上,就是el-menu-item的router属性,它的值是vue router对象,通过尝试发现:default-active匹配的是index值,当将el-menu的route属性设置为true时,跳转的路由如果没有设置router,则使用的是index的值,如果写了router,则路由使用的是router的值,通过这一点儿特性,于是想了一个办法:

  在router.js里设置路由时,给相同导航高亮的路由设置相同的name属性,如图:

 

 

 然后在menu组件上设置default-active的值为:$route.name,这样就可以实现刷新时导航栏选中当前页的问题。最后设置el-menu-item的index属性为router.js文件里跳转路由的name值,router属性为:路由的path,如图:

 

 通过这样设置,就可以实现刷新页面时,导航栏的选中项和页面显示一致,并且从b页面跳转到c页面时,还能保持b选中的状态。

效果图如下:

 

 

 

 

 

 最后点击去“child1”的按钮,跳转到child1,导航栏会自动选中到导航一。

至于,刷新问题和跳转页面时导航栏的选中问题就解决了。

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!