v-link
最后更新于:2022-04-01 07:41:06
# v-link
`v-link` 是一个用来让用户在 vue-router 应用的不同路径间跳转的指令。该指令接受一个 JavaScript 表达式,并会在用户点击元素时用该表达式的值去调用 `router.go`。
``` html
<!-- 字面量路径 -->
<a v-link="'home'">Home</a>
<!-- 效果同上 -->
<a v-link="{ path: 'home' }">Home</a>
<!-- 具名路径 -->
<a v-link="{ name: 'user', params: { userId: 123 }}">User</a>
```
你应该使用 `v-link` 而不是 `href` 来处理浏览时的跳转。原因如下:
- 它在 HTML5 history 模式和 hash 模式下的工作方式相同,所以如果你决定改变模式,或者 IE9 浏览器退化为 hash 模式时,都不需要做任何改变。
- 在 HTML5 history 模式下,`v-link` 会监听点击事件,防止浏览器尝试重新加载页面。
- 在 HTML5 history 模式下使用 `root` 选项时,不需要再 `v-link` 的 URL 中包含 root 路径。
#### 链接活跃时的 class
带有 `v-link` 指令的元素,如果 `v-link` 对应的 URL 匹配当前的路径,该元素会被添加特定的 class。默认添加的 class 是 `.v-link-active`,而判断是否活跃使用的是**包含性匹配**。举例来说,一个带有指令 `v-link="/a"` 的元素,只要当前路径以 `/a` 开头,此元素即会被判断为活跃。
连接是否活跃的匹配也可以通过 `exact` 内联选项来设置为只有当路径完全一致时才匹配:
``` html
<a v-link="{ path: '/a', exact: true }"></a>
```
链接活跃时的 class 名称可以通过在创建路由器实例时指定 `activeLinkClass` 全局选项 来自定义,也可以通过 `activeClass` 内联选项来单独指定:
``` html
<a v-link="{ path: '/a', activeClass: 'custom-active-class' }"></a>
```
#### 其他选项
- **replace**
一个带有 `replace: true` 的链接被点击时将会触发 `router.replace()` 而不是 `router.go()`。由此产生的跳转不会留下历史记录:
``` html
<a v-link="{ path: '/abc', replace: true }"></a>
```
- **append**
带有 `append: true` 选项的相对路径链接会确保该相对路径始终添加到当前路径之后。举例来说,从 `/a` 跳转到相对路径 `b` 时,如果没有 `append: true` 我们会跳转到 `/b`,但有 `append: true` 则会跳转到 `/a/b`。
``` html
<a v-link="{ path: 'relative/path', append: true }"></a>
```
#### 其他注意点
- `v-link` 会自动设置 `<a>` 的 `href` 属性。
- 由于 `v-link` 是个[字面量指令](http://vuejs.org/guide/directives.html#Literal_Directives),它可以包含 mustache 标签,例如 `v-link="/user/{% raw %}{{user.name}}{% endraw %}"` 。