时间:2020-10-03 10:13:44 | 栏目:vue | 点击:次
前言: 在项目中,我用到了vue +iview + vue-router 开发; 然后导航条就使用了iview的Menu组件,结果发觉导航条的内容点击一次之后不会显示高亮样式,而是先跳转了,我再点击一次,才会高亮显示。
在看了vue-router的文档之后,发觉有一个很好用的东西,就是router-link的属性: active-class 和 exact。
为什么要使用router-link? 官网上说明了这几点好处:
组件支持用户在具有路由功能的应用中(点击)导航。 通过 to 属性指定目标地址,默认渲染成带有正确链接的 a 标签,可以通过配置 tag 属性生成别的标签.。另外,当目标路由成功激活时,链接元素自动设置一个表示激活的 CSS 类名。
比起写死的 <a href="..." rel="external nofollow" > 会好一些,理由如下:
无论是 HTML5 history 模式还是 hash 模式,它的表现行为一致,所以,当你要切换路由模式,或者在 IE9 降级使用 hash 模式,无须作任何变动。
在 HTML5 history 模式下,router-link 会守卫点击事件,让浏览器不再重新加载页面。
当你在 HTML5 history 模式下使用 base 选项之后,所有的 to 属性都不需要写(基路径)了。
首先, active-class可以指定一个高亮时的样式, 比如我定义一个白色粗体的样式:
color: #fff; font-weight: bold; }
然后,就是exact,文档介绍是这样的
exact
类型: boolean
默认值: false
“是否激活” 默认类名的依据是 inclusive match (全包含匹配)。 举个例子,如果当前的路径是 /a 开头的,那么 也会被设置 CSS 类名。
按照这个规则,每个路由都会激活!想要链接使用 “exact 匹配模式”,则使用 exact 属性:
<!-- 这个链接只会在地址为 / 的时候被激活 --> <router-link to="/" exact>
在考虑到Menu组件的默认css可能会影响我的导航栏,所以我果断不用Menu组件,然后使用ul标签;最后,我的代码长这样:
<ul> <li> <router-link to="/" active-class="active" > 首页</roouter-link> </li> </ul>
然后,官网上还可以这样玩:
“` <router-link to="/" active-class="active" tag="li" ><a>首页</a></roouter-link> </ul> ```