路由配置项
路由配置项位于 /lavas.config.js
的 router
对象。Lavas 内部使用 vue-router 进行路由管理,因此许多配置项都和 vue-router 是相同的。
Lavas 路由配置项包括:
- 路由模式,基准路由等
- 路由切换动画效果
- 重写路由(如果对自动生成的路由规则不满意)
路由模式和基准路由
router: {
mode: 'history',
base: '/',
// ...
}
mode
和 base
都是 vue-router 的配置项,分别用来定义路由模式和路由基础路径。
mode
可选值有 'hash'
和 'history'
('abstract'
只作用于服务端,这里并没有使用的必要)。注意的是在 SSR 模式下不支持 hash
。
base
用以定义整个项目的的基础路径,正常情况为 /
。如果开发者希望将整个服务部署在 https://some.domain/app/
, 那么这里就应该填写 /app/
。注意最后的 /
不能遗漏。
这两个配置项也可以参考 vue-router 的文档中 mode 和 base 部分。
页面切换动画
Lavas 使用了 vue-router 的过渡动效 实现页面切换动画。我们内置了两种切换动画:渐隐渐现和左右滑动。同时也提供了自定义动画的配置方式。
渐隐渐现
效果表现为打开新页面渐显,返回旧页面时渐隐。
在 pageTransition
中有两个可配置项:
type
必填项,渐隐渐现效果必须填写fade
transitionClass
选填,默认值为fade
。可以指定 Vue Transition 的类名,例如默认会应用fade-enter/fade-leave-active
样式类。router: {
pageTransition: {
type: 'fade',
transitionClass: 'fade'
}
}
对应的 transition 样式部分在 core/App.vue
中,可以根据实际情况进行调整。
&.transition-fade
opacity 1
transition opacity 1s ease
&.fade-enter
opacity 0
&.fade-leave-active
opacity 0
左右滑动
页面左右滑动效果具体表现为:打开新页面时左滑展示,返回之前的页面时右滑退出。
在 pageTransition
中有以下可配置项:
type
必填项,左右切换效果必须填写slide
slideLeftClass
选填,默认值为slide-left
。可以指定左滑 Vue Transition 的类名,例如默认会应用slide-left-enter
样式类。slideRightClass
选填,默认值为slide-right
。可以指定右滑 Vue Transition 的类名,例如默认会应用slide-right-enter
样式类。alwaysBackPages
选填,访问以下路由路径永远右滑后退。例如在切换到主页的场景下,通常希望表现为后退。alwaysForwardPages
选填,访问以下路由路径永远左滑前进。
router: {
pageTransition: {
type: 'slide',
slideLeftClass: 'slide-left',
slideRightClass: 'slide-right',
alwaysBackPages: ['index'],
alwaysForwardPages: []
}
}
对应的 transition 样式部分在 core/App.vue
中,可以根据实际情况进行调整。
&.transition-slide
transition transform 0.4s cubic-bezier(.55, 0, .1, 1)
&.slide-left-enter,
&.slide-right-leave-active
transform translate(100%, 0)
&.slide-right-enter,
&.slide-left-leave-active
transform translate(-100%, 0)
自定义动画
除了以上两种内置的切换效果,开发者还可以通过 pageTransition
自定义动画:
type
必填项,可填写自定义效果。transitionClass
必填项。可以指定 Vue Transition 的类名,例如填写myeffect
将应用myeffect-enter/myeffect-leave-active
样式类。router: {
pageTransition: {
type: 'myeffect',
transitionClass: 'myeffect'
}
}
重写路由对象
Lavas 会根据 /pages
文件夹内的目录结构,自动生成 vue-router 路由对象。具体生成规则可以参考这里。
在某些复杂场景下,如果自动生成不能够完全满足需求,此时就需要通过路由配置对象进行重写了。
router: {
rewrite: [],
routes: [],
// ...
}
下面我们将分别介绍这两个配置项的用法和使用场景。
使用 rewrite 修改路由路径
这个配置项可以定义一组规则,用来重写 Lavas 自动生成的路由路径。举例来说,如果项目中存在 /pages/Detail.vue
这样一个路由组件,Lavas 会自动生成 /detail
这样一条路由路径,如果想重写这条路径,例如加上 rewrite
前缀,可以这么做:
rewrite: [
{
from: '/detail',
to: '/rewrite/detail'
}
]
其中每一条重写规则包括两个属性:
from
匹配规则,支持以下三种类型:- 正则
RegExp
,内部会调用path.replace(from, to)
进行路由路径的重写 - 数组
Array
,存在于数组中的路由路径会被重写 - 字符串,完全匹配的路由路径会被重写
- 正则
to
重写路径,from
为数组或字符串时,必须是字符串类型;from
为正则时,除了字符串还可以是一个函数,可以参考 replace 指定一个函数作为参数
注意事项
这里有一点需要注意,在 rewrite
中与 from
进行匹配的路由路径,是 route.path
,并不是路径的完整形式,即 route.fullPath
。
请看下面这个嵌套路由的例子,包含了一个父路由 /detail
和一个子路由 /detail/:id
:
{
path: '/detail',
name: 'detail',
component: _1513...,
children: [{
path: ':id',
name: 'detailId',
component: _15130...
}]
}
应用以下 rewrite
规则将影响父路由组件的路径,当然子路由路径也跟着变成了 /rewrite/detail/:id
:
rewrite: [
{
from: '/detail',
to: '/rewrite/detail'
}
]
在上面的场景中一切正常,但如果仅仅想修改子路由组件,而不想影响到父路由组件,我们的 rewrite
规则就只能这么写了,类似 ':id'
这样的写法实在很容易造成重名现象,进而影响到其他不相干的路由:
rewrite: [
{
from: ':id',
// 不能写成 /detail/:id
to: '/rewrite/:id'
}
]
可以看出 rewrite
适合重写父组件的路径,从而批量影响其下的所有子路由。而在需要精确修改某一条路由尤其是子路由的时候,就需要使用下面介绍的 routes
了。
使用 routes 修改路由对象
虽然用 rewrite
可以便捷地重写路由路径,但是路由对象不仅仅只有路径这一个属性。如果想更精确地修改 Lavas 自动生成的路由对象,可以使用 routes
配置项。该配置项是一个包含了路由对象的数组,其中路由对象包含以下可配置项:
pattern
字符串或者是正则。与rewrite
不同,使用route.fullPath
进行匹配path
重写路由路径。lazyLoading
是否需要路由懒加载,布尔值。chunkname
异步路由 chunk 名称。最终会生成一个[chunkname].[hash].js
异步路由文件。配置此项后可以不用额外配置lazyLoading
,默认打开alias
别名,在这里也可以进行路由路径的重新定义,但是由于仅仅是别名,原路由路径依然可以访问meta
路由元信息,可以将一些自定义属性挂载在上面,便于后续访问scrollBehavior
滚动行为函数。如果不配置,将使用内置的默认函数,切换路由时将记录上一次的滚动距离,对于希望滚动到顶的路由组件,可以在路由元信息中配置meta.scrollToTop
为true
在下面的例子中,我们希望将所有路径中包含 /detail
的路由组件打包到一个 chunk 中,并命名为 my-chunk
,同时加上 keepAlive
这个元信息供后续使用:
routes: [
{
pattern: /\/detail/,
lazyLoading: true,
chunkname: 'my-chunk',
meta: {
keepAlive: true
}
}
]