需求:实现导航高亮效果
vue-router提供了一个全局组件router-link(取代a标签)
将a标签的代码进行替换:

审查元素将新增的类改变属性:(router-link-exact-active 和 router-link-active)

说明:我们发现router-link自动给当前导航添加了两个高亮类名(router-link-exact-active 和 router-link-active)
router-link-ctive模糊匹配(用的多)
to="/my" => 可以匹配'/my'开头的所有路径,如/my,/my/a/...
router-link-exact-active精确匹配
to="/my" => 仅可以匹配/my
说明:router-link的两个高亮类名太长了,我们希望能定制怎么办?
const router = new VueRouter({
routes: [...],
linkActiveclass: "类名1",
linkExactActiveclass: "类名2"
})
上述操作相当于实现了自定义的类名,将两个高亮的类名进行自定义以达到简写或其他目的。
在跳转路由时,进行传值,有一下两种方式:
参数传递:
热门搜索:
程序员
前端培训
如何成为前端大牛
参数接收:
搜索关键字: {{ $route.query.key }}
使用传递过来的值:
搜索关键字: {{ $route.query.key }}
动态路由传参
配置动态路由
const router = new VueRouter({
routes: [
{ path: '/search/:参数名', component: Search }
]
})
配置导航链接
对应页面组件接收传递过来的值
参数传递:
热门搜索:
程序员
前端培训
如何成为前端大牛
参数接受:
搜索关键字: {{ $route.params.words }}
使用传递过来的参数:
两种传参方式哪种要好一些:
- 查询参数传参((比较适合传多个参数)
- 动态路由传参(优雅简洁,传单个参数比较方便)
问题:配了路由path: "/search/:words”为什么按下面步骤操作,路径上没有参数,会未匹配到组件,显示空白?

原因:/search/:words表示,必须要传参数。如果不传参数,也希望匹配,可以加个可选符"?"
解决:
const router = new VueRouter({
routes: [
{ path: '/home', component: Home },
{ path: '/search/:words?', component: Search }
]
})