npm install
路由替换区域:
<router-view></router-view>
子路由:
router.map({
'/index':{
component:Index,
subRoutes:{
'/':{
component:{
template:'<p>这是默认的嵌套子路由</p>'
}
}
}
}
})
路由对象暴露了以下几个属性:
$route.path,字符串,当前路由对象的路径,如:"/foo/bar"$route.params,对象,包含路由中动态片段和全匹配片段的键值对$route.query,对象,包含路由中查询参数的键值对,例:/foo?user=1会得到$route.query.user=1$route.router,路由规则所属的路由器及其所属的组件$route.matched,数组:包含当前匹配路径中所包含的所有片段所对应的配置参数对象$route.name,当前路径的名字
另外在路由设置对象中自定义的其他字段也会最终拷贝到路由对象上
可以直接在组件的模板中使用$route,如
<div>
<p>当前路径: {{$route.path}}</p>
<p>当前路由参数: {{$route.params | json}}</p>
</div>
route.map({
'/user/:username':{
component:{
template:"<p>用户名是{{$route.params.username}}</p>"
}
}
})
给一条路径加上一个名字能够让我们更方便地进行路径的跳转
默认值true,会以#!开头
默认false,true情况下利用H5的利用 history.pushState() 和 history.replaceState() 来管理浏览历史记录
默认 false,利用一个不依赖于浏览器的浏览历史虚拟管理后端,虚拟模式在测试或者实际的url并不重要的时候,非常有用,如Electron 或者 Cordova 应用。在非浏览器模式下,路由器同样会退化为抽象模式。
默认null,只在H5 history模式下可用
默认值:v-link-active 配置当v-link元素匹配的路径时候需要添加到元素上的class
默认值:false 只在h5 history模式下可用,当用户点击后退按钮的时候,借助H5 history中的popstate事件对应的state来重置页面的滚动位置.
默认值:false 初次加载时候是否对<route-view></route-view>处理场景切换效果.
默认值:false,在切换钩子函数中发生异常不吞掉
用于渲染匹配的组件,可以传递props,v-transition和transition-mode完整支持,v-ref支持,被渲染的对象会注册到父级组件的this.$对象上.
但是不支持wait-for,需要使用切换钩子函数 active控制切换的时机.
用来让用户在不同路径之间跳转的指令,接受一个表达式,并在点击该元素时去调用router.go.
- replace,触发
router.replace(),不会留下历史记录 - append,
'/a'点击跳转'/a/b' - v-link会自动
<a>的href属性,并且可以包含mustache标签
transition.from
//一个代表当前路径的路由对象。
transition.to
//一个代表将要切换到的路径的路由对象。
transition.next()
//调用此函数处理切换过程的下一步。
transition.abort([reason])
//调用此函数来终止或者拒绝此次切换。
transition.redirect(path)
//取消当前切换并重定向到另一个路由。
-
data参数transition,activate被断定resolve,可以传递参数 -
activivateresolve->transition(next)reject(reason)->transition.abort(reason) -
deactivateresolve->transition(next)reject(reason)->transition.abort(reason) -
canActivate- resolve(true) -> transition.next()
- resolve(false) -> transition.abort()
- reject(reason) -> transition.abort(reason)
- true -> transition.next()
- false -> transition.abort()
-
canDeactivate -
canReuse返回布尔类型,默认true