

路由元信息
我的理解就是 他可以把路由的父路径都列举出来,完成一些任务,比如登录,user 组件需要登录,那么user下面的foo组件也需要,那么可以通过这个属性 来检测这个路由线上 的一些状态。
定义路由的时候可以配置 meta 字段:
const router = new VueRouter({
 routes: [
 {
 path: '/foo',
 component: Foo,
 children: [
 {
 path: 'bar',
 component: Bar,
 // a meta field
 meta: { requiresAuth: true }
 }
 ]
 }
 ]
})首先,我们称呼 routes 配置中的每个路由对象为 路由记录。路由记录可以是嵌套的,因此,当一个路由匹配成功后,他可能匹配多个路由记录
例如,根据上面的路由配置,/foo/bar 这个 URL 将会匹配父路由记录以及子路由记录。
一个路由匹配到的所有路由记录会暴露为 $route 对象(还有在导航守卫中的路由对象)的 $route.matched 数组。因此,我们需要遍历 $route.matched 来检查路由记录中的 meta 字段。
下面例子展示在全局导航守卫中检查元字段:
router.beforeEach((to, from, next) => {
 if (to.matched.some(record => record.meta.requiresAuth)) {
 // this route requires auth, check if logged in
 // if not, redirect to login page.
 if (!auth.loggedIn()) {
 next({
 path: '/login',
 query: { redirect: to.fullPath }
 })
 } else {
 next()
 }
 } else {
 next() // 确保一定要调用 next()
 }
})数据获取
我的理解就是在哪里获取数据,可以再组件里面,也可以在组件的守卫里面,也就是组件的生命周期里面。
有时候,进入某个路由后,需要从服务器获取数据。例如,在渲染用户信息时,你需要从服务器获取用户的数据。我们可以通过两种方式来实现:
导航完成之后获取:先完成导航,然后在接下来的组件生命周期钩子中获取数据。在数据获取期间显示『加载中』之类的指示。
导航完成之前获取:导航完成前,在路由进入的守卫中获取数据,在数据获取成功后执行导航。
从技术角度讲,两种方式都不错 —— 就看你想要的用户体验是哪种。
导航完成后获取数据
当你使用这种方式时,我们会马上导航和渲染组件,然后在组件的 created 钩子中获取数据。这让我们有机会在数据获取期间展示一个 loading 状态,还可以在不同视图间展示不同的 loading 状态。
假设我们有一个 Post 组件,需要基于 $route.params.id 获取文章数据:
<template>
 <p class="post">
 <p class="loading" v-if="loading">
 Loading...
 </p>
 <p v-if="error" class="error">
 {{ error }}
 </p>
 <p v-if="post" class="content">
 <h2>{{ post.title }}</h2>
 <p>{{ post.body }}</p>
 </p>
 </p>
</template>
export default {
 data () {
 return {
 loading: false,
 post: null,
 error: null
 }
 },
 created () {
 // 组件创建完后获取数据,
 // 此时 data 已经被 observed 了
 this.fetchData()
 },
 watch: {
 // 如果路由有变化,会再次执行该方法
 '$route': 'fetchData'
 },
 methods: {
 fetchData () {
 this.error = this.post = null
 this.loading = true
 // replace getPost with your data fetching util / API wrapper
 getPost(this.$route.params.id, (err, post) => {
 this.loading = false
 if (err) {
 this.error = err.toString()
 } else {
 this.post = post
 }
 })
 }
 }
}在导航完成前获取数据
通过这种方式,我们在导航转入新的路由前获取数据。我们可以在接下来的组件的 beforeRouteEnter 守卫中获取数据,当数据获取成功后只调用 next 方法。
export default {
 data () {
 return {
 post: null,
 error: null
 }
 },
 beforeRouteEnter (to, from, next) {
 getPost(to.params.id, (err, post) => {
 next(vm => vm.setData(err, post))
 })
 },
 // 路由改变前,组件就已经渲染完了
 // 逻辑稍稍不同
 beforeRouteUpdate (to, from, next) {
 this.post = null
 getPost(to.params.id, (err, post) => {
 this.setData(err, post)
 next()
 })
 },
 methods: {
 setData (err, post) {
 if (err) {
 this.error = err.toString()
 } else {
 this.post = post
 }
 }
 }
}在为后面的视图获取数据时,用户会停留在当前的界面,因此建议在数据获取期间,显示一些进度条或者别的指示。如果数据获取失败,同样有必要展示一些全局的错误提醒。
相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!
推荐阅读:
vue+Echarts实现点击高亮(附代码)
用vue让a标签点击高亮(附代码)
