您现在的位置是:首页 > 数码 > 

vue 中使用element

2025-07-18 18:50:11
vue 中使用element 在使用element中的menu组件时,根据官方文档,可以设置给el-menu设置router属性为:true,给el-menu-item设置index的值为路径,就可以实现点击导航跳转到指定路由。 这样做虽然能实现跳转,但是,若刷新浏览器,则导航会跳转

vue 中使用element

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

这样做虽然能实现跳转,但是,若刷新浏览器,则导航会跳转到默认的选中项,而不是我们离开时的导航。

 百度时大部分回答是将default-active属性设置为:$route.path,这样页面重新渲染时就会选中当前的路由了。可是,解决了刷新的问题,还有一个从页面上的按钮跳转到其他页面的问题,比如导航列表:a路由(导航一)、b路由(导航二),从b可以跳转c,跳转到c时,导航栏选中的应该是导航二,然而设置为$route.path 后,此时因为路由变了,不到与index匹配的路由了,导航栏就不会再高亮了。

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

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

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

效果图如下:



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

至此,刷新问题和跳转页面时导航栏的选中问题就解决了。
-------------------------------------------------------------------------------------分割线------------------------------------------------------------------------------------------

刚又想了另外一种方法,与上述方法有异曲同工之妙,哈哈哈哈!

先将路由这样修改:

这样name属性不用一致了,只需要设置需要高亮相同导航栏的路由的路径有相同的路径,如:/two/*,然后设置menu组件上的参数:

default-active有计算属性getActive得到,如下图:

这样设置之后,也可以达到上述的效果。

#感谢您对电脑配置推荐网 - 最新i3 i5 i7组装电脑配置单推荐报价格的认可,转载请说明来源于"电脑配置推荐网 - 最新i3 i5 i7组装电脑配置单推荐报价格

本文地址:http://www.dnpztj.cn/shuma/842828.html

相关标签:无
上传时间: 2024-02-04 02:42:39
留言与评论(共有 18 条评论)
本站网友 江风益
13分钟前 发表
效果图如下: 最后点击去“child1”的按钮,跳转到child1,导航栏会自动选中到导航一
本站网友 康桥二手房
19分钟前 发表
效果图如下: 最后点击去“child1”的按钮,跳转到child1,导航栏会自动选中到导航一
本站网友 tm2009下载
16分钟前 发表
本站网友 红豆减肥法
7分钟前 发表
百度时大部分回答是将default-active属性设置为:$route.path,这样页面重新渲染时就会选中当前的路由了
本站网友 北京艾丽斯妇科医院
25分钟前 发表
百度时大部分回答是将default-active属性设置为:$route.path,这样页面重新渲染时就会选中当前的路由了
本站网友 石家庄大桥外语
0秒前 发表
至此,刷新问题和跳转页面时导航栏的选中问题就解决了
本站网友 林小宅
20分钟前 发表
本站网友 骐骥一跃不能十步
18分钟前 发表
b路由(导航二),从b可以跳转c,跳转到c时,导航栏选中的应该是导航二,然而设置为$route.path 后,此时因为路由变了,不到与index匹配的路由了,导航栏就不会再高亮了
本站网友 复方利血平片
18分钟前 发表
至此,刷新问题和跳转页面时导航栏的选中问题就解决了
本站网友 怎样瘦小腿
29分钟前 发表
最后设置el-menu-item的index属性为router.js文件里跳转路由的name值,route属性为:路由的path,如图: 通过这样设置,就可以实现刷新页面时,导航栏的选中项和页面显示一致,并且从b页面跳转到c页面时,还能保持b选中的状态
本站网友 俊情一点
14分钟前 发表
可是,解决了刷新的问题,还有一个从页面上的按钮跳转到其他页面的问题,比如导航列表:a路由(导航一)
本站网友 广州动物园
23分钟前 发表
-------------------------------------------------------------------------------------分割线------------------------------------------------------------------------------------------ 刚又想了另外一种方法,与上述方法有异曲同工之妙,哈哈哈哈! 先将路由这样修改: 这样name属性不用一致了,只需要设置需要高亮相同导航栏的路由的路径有相同的路径,如:/two/*,然后设置menu组件上的参数: default-active有计算属性getActive得到,如下图: 这样设置之后,也可以达到上述的效果
本站网友 上帝武装
10分钟前 发表
本站网友 华军软件
3分钟前 发表
至此,刷新问题和跳转页面时导航栏的选中问题就解决了
本站网友 中药骨碎补
9分钟前 发表
最后设置el-menu-item的index属性为router.js文件里跳转路由的name值,route属性为:路由的path,如图: 通过这样设置,就可以实现刷新页面时,导航栏的选中项和页面显示一致,并且从b页面跳转到c页面时,还能保持b选中的状态
本站网友 广州邮政
2分钟前 发表
-------------------------------------------------------------------------------------分割线------------------------------------------------------------------------------------------ 刚又想了另外一种方法,与上述方法有异曲同工之妙,哈哈哈哈! 先将路由这样修改: 这样name属性不用一致了,只需要设置需要高亮相同导航栏的路由的路径有相同的路径,如:/two/*,然后设置menu组件上的参数: default-active有计算属性getActive得到,如下图: 这样设置之后,也可以达到上述的效果
本站网友 胎记图片
30分钟前 发表
至此,刷新问题和跳转页面时导航栏的选中问题就解决了