vue iview的菜单组件Mune 点击不高亮的解决方案
前言:在项目中,我用到了vue+iview+vue-router开发;然后导航条就使用了iview的Menu组件,结果发觉导航条的内容点击一次之后不会显示高亮样式,而是先跳转了,我再点击一次,才会高亮显示。
在看了vue-router的文档之后,发觉有一个很好用的东西,就是router-link的属性:active-class和exact。
为什么要使用router-link?官网上说明了这几点好处:
组件支持用户在具有路由功能的应用中(点击)导航。通过to属性指定目标地址,默认渲染成带有正确链接的a标签,可以通过配置tag属性生成别的标签.。另外,当目标路由成功激活时,链接元素自动设置一个表示激活的CSS类名。
比起写死的
无论是HTML5history模式还是hash模式,它的表现行为一致,所以,当你要切换路由模式,或者在IE9降级使用hash模式,无须作任何变动。
在HTML5history模式下,router-link会守卫点击事件,让浏览器不再重新加载页面。
当你在HTML5history模式下使用base选项之后,所有的to属性都不需要写(基路径)了。
首先,active-class可以指定一个高亮时的样式,比如我定义一个白色粗体的样式:
color:#fff; font-weight:bold; }
然后,就是exact,文档介绍是这样的
exact
类型:boolean
默认值:false
“是否激活”默认类名的依据是inclusivematch(全包含匹配)。举个例子,如果当前的路径是/a开头的,那么也会被设置CSS类名。
按照这个规则,每个路由都会激活!想要链接使用“exact匹配模式”,则使用exact属性:
在考虑到Menu组件的默认css可能会影响我的导航栏,所以我果断不用Menu组件,然后使用ul标签;最后,我的代码长这样:
-
首页
然后,官网上还可以这样玩:
“`首页 ```
以上这篇vueiview的菜单组件Mune点击不高亮的解决方案就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。