Vue2.0 探索之路——vue-router入门教程和总结

前言

这是关于vue的第三篇博文。html

前两篇:
Vue2.0 探索之路——生命周期和钩子函数的一些理解
Vue2.0 探索之路——vuex入门教程和思考前端

没想到写的还有人看,正是由于大家的阅读和点赞收藏,才给了我无比的动力。请关注个人专栏,我不会停更的。vue

最近也一直在想,前端知识怎么提升,前端知识的碎片化,让我感受好多好多都不会,以为这个时候我应该肯定一个方向,重点的培养本身的招牌技能,再加以辅助技能。不过看了不少博文也暂时没有造成具体的路线,就先暂定写博文吧。webpack

今天主要讲解一下 vue-router 的相关知识,路由路由嘛,在单页应用里仍是蛮重要的。web

安装和引入

首先咱们先安装依赖
npm install vue-routervue-router

紧接着项目引入,看下面的图噢,很是清晰,代码就本身敲吧。vuex

router.js 的配置

首先引入 vue-router组件,Vue.use是用来加载全局组件的。那下面咱们就开始看看这个VueRouter的写法和配置吧。npm

mode: 编程

默认为hash,可是用hash模式的话,页面地址会变成被加个#号比较难看了, http://localhost:8080/#/linkParams/xuxiao
因此通常咱们会采用 history模式,它会使得咱们的地址像日常同样。http://localhost:8080/linkParams/xuxiaosegmentfault

base
应用的基路径。例如,若是整个单页应用服务在 /app/ 下,而后 base 就应该设为 "/app/"。
通常写成 __dirname,在webpack中有配置。

routes
routes就是咱们的大核心了,里面包含咱们全部的页面配置。
path 很简单,就是咱们的访问这个页面的路径
name 给这个页面路径定义一个名字,当在页面进行跳转的时候也能够用名字跳转,要惟一哟
component 组件,就是我们在最上面引入的 import ...了,固然这个组件的写法还有一种懒加载

懒加载的方式,咱们就不须要再用import去引入组件了,直接以下便可。懒加载的好处是当你访问到这个页面的时候才会去加载相关资源,这样的话能提升页面的访问速度。
component: resolve => require(['./page/linkParamsQuestion.vue'], resolve)

router的使用

对于vue-router的使用,详细的能够看看文档,可是你知道的,文档也只是一个指引,具体的实现仍是得靠本身码代码哟。不过我把官方文档放在下面,有兴趣的能够去看看。

router.vuejs.org/zh-cn/index…

我通读文档 + 代码实现再结合平时项目开发的使用状况,主要讲下面几个点。

router传参数

在咱们的平时开发跳转里,很明显,传参数是必要的。那么在vue-router中如何跳转,如何传参数呢。请看下面。

1.路由匹配参数

首先在路由配置文件router.js中作好配置。标红出就是对 /linkParams/的路径作拦截,这种类型的连接后面的内容会被vue-router映射成name参数。

代码中获取 name的方式以下:

let name = this.$route.params.name; // 连接里的name被封装进了 this.$route.params复制代码

2.Get请求传参

这个明明实在很差形容啊。不过真的是和Get请求同样。你彻底能够在连接后加上?进行传参。

样例:http://localhost:8080/linkParamsQuestion?age=18

项目里获取:

let age = this.$route.query.age;   //问号后面参数会被封装进 this.$route.query;复制代码

编程式导航

这里就开始利用vue-router讲发起跳转了。其实也很是简单,主要利用 <router-link>来建立可跳转连接,还能够在方法里利用 this.$router.push('xxx') 来进行跳转。

样例<router-link to="/linkParams/xuxiao">点我不会怀孕</router-link>
上面的这个router-link就至关于加了个可跳转属性。

至于this.$router.push这里直接用官网的荔枝了

// 字符串,这里的字符串是路径path匹配噢,不是router配置里的name
this.$router.push('home')

// 对象
this.$router.push({ path: 'home' })

// 命名的路由 这里会变成 /user/123
this.$router.push({ name: 'user', params: { userId: 123 }})

// 带查询参数,变成 /register?plan=private
this.$router.push({ path: 'register', query: { plan: 'private' }})复制代码

导航钩子

导航钩子函数,主要是在导航跳转的时候作一些操做,好比能够作登陆的拦截,而钩子函数根据其生效的范围能够分为 全局钩子函数路由独享钩子函数组件内钩子函数

全局钩子函数

能够直接在路由配置文件router.js里编写代码逻辑。能够作一些全局性的路由拦截。

router.beforeEach((to, from, next)=>{
  //do something
  next();
});
router.afterEach((to, from, next) => {
    console.log(to.path);
});复制代码

每一个钩子方法接收三个参数:

  • to: Route: 即将要进入的目标 路由对象
  • from: Route: 当前导航正要离开的路由
  • next: Function: 必定要调用该方法来 resolve 这个钩子。执行效果依赖 next 方法的调用参数。

  • next(): 进行管道中的下一个钩子。若是所有钩子执行完了,则导航的状态就是 confirmed (确认的)。

    • next(false): 中断当前的导航。若是浏览器的 URL 改变了(多是用户手动或者浏览器后退按钮),那么 URL 地址会重置到 from 路由对应的地址。

    • next('/') 或者 next({ path: '/' }): 跳转到一个不一样的地址。当前的导航被中断,而后进行一个新的导航。

确保要调用 next 方法,不然钩子就不会被 resolved。

路由独享钩子函数

能够作一些单个路由的跳转拦截。在配置文件编写代码便可

const router = new VueRouter({
  routes: [
    {
      path: '/foo',
      component: Foo,
      beforeEnter: (to, from, next) => {
        // ...
      }
    }
  ]
})复制代码

组件内钩子函数

更细粒度的路由拦截,只针对一个进入某一个组件的拦截。

const Foo = {
  template: `...`,
  beforeRouteEnter (to, from, next) {
    // 在渲染该组件的对应路由被 confirm 前调用
    // 不!能!获取组件实例 `this`
    // 由于当钩子执行前,组件实例还没被建立
  },
  beforeRouteUpdate (to, from, next) {
    // 在当前路由改变,可是该组件被复用时调用
    // 举例来讲,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候,
    // 因为会渲染一样的 Foo 组件,所以组件实例会被复用。而这个钩子就会在这个状况下被调用。
    // 能够访问组件实例 `this`
  },
  beforeRouteLeave (to, from, next) {
    // 导航离开该组件的对应路由时调用
    // 能够访问组件实例 `this`
  }
}复制代码

钩子函数使用场景

其实路由钩子函数在项目开发中用的并非很是多,通常用于登陆态的校验,没有登陆跳转到登陆页;权限的校验等等。固然随着项目的开发进展,也会有更多的功能可能用钩子函数实现会更好,咱们知道有钩子函数这个好东西就好了,下次遇到问题脑海就能浮现,噢,这个功能用钩子实现会比较棒。咱们的目的就达到了。固然,有兴趣的能够再去研究下源码的实现。开启下脑洞。

##其余知识点

滚动行为

在利用vue-router去作跳转的时候,到了新页面若是对页面的滚动条位置有要求的话,能够利用下面这个方法。

const router = new VueRouter({
  routes: [...],
  scrollBehavior (to, from, savedPosition) {
    // return 指望滚动到哪一个的位置
  }
})复制代码

scrollBehavior 方法接收 tofrom 路由对象。
第三个参数 savedPosition 当且仅当 popstate 导航 (modehistory 经过浏览器的 前进/后退 按钮触发) 时才可用。
这里就不细致的讲了,文档都有也很是简单,记住有这个东西就行。

//全部路由新页面滚动到顶部:
scrollBehavior (to, from, savedPosition) {
  return { x: 0, y: 0 }
}

//若是有锚点
scrollBehavior (to, from, savedPosition) {
  if (to.hash) {
    return {
      selector: to.hash
    }
  }
}复制代码

路由元信息

这个概念很是简单,就是在路由配置里有个属性叫 meta,它的数据结构是一个对象。你能够放一些key-value进去,方便在钩子函数执行的时候用。
举个例子,你要配置哪几个页面须要登陆的时候,你能够在meta中加入一个 requiresAuth标志位。

const router = new VueRouter({
  routes: [
    {
      path: '/foo',
      component: Foo,
      meta: { requiresAuth: true }
    }
  ]
})复制代码

而后在 全局钩子函数 beforeEach中去校验目标页面是否须要登陆。

router.beforeEach((to, from, next) => {
  if (to.matched.some(record => record.meta.requiresAuth)) {
    //校验这个目标页面是否须要登陆
    if (!auth.loggedIn()) {  
      next({
        path: '/login',
        query: { redirect: to.fullPath }
      })
    } else {
      next()
    }
  } else {
    next() // 确保必定要调用 next()
  }
})复制代码

这个auth.loggedIn 方法是外部引入的,你能够先写好一个校验是否登陆的方法,再importrouter.js中去判断。

总结

总的来看,vue-router是比较简单的,重点就是路由匹配,编程式导航,钩子函数。这篇只是一个vue-router的实用的知识点的梳理讲解,成文有点杂~..~。

相关文章
相关标签/搜索