在使用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,导航栏会自动选中到导航一。
至于,刷新问题和跳转页面时导航栏的选中问题就解决了。