浅谈对路由的理解

什么是路由?

  根据不同的url展示不同的页面或者数据。

分类:路由分为前端路由和后端路由。

前端路由:主要用于单页面的开发,根据用户请求的地址来渲染不同的页面。前端路由不会经过后端,而是根据hash值的变化进行页面数据的渲染,所以不会刷新,不跳转。

  原理:通过hashRouter(onhashchange)或者history路由(h5 historyAPI)进行页面的切换。

后端路由:根据用户请求的路径返回不同的页面或数据。

 

routes:

  它是路由配置的一些规则,是一个数组,数组中的每一个对象都是一个路由的配置项。

export const router=new VueRouter({
    routes:[{},{},{}]     
})

 

 

<router-link>和<router-view>:

  当路由配置成功后,VueRouter会提供2个内置组件用来做组件的显示:

    <router-link>:路由组件展示

    <router-view>:路由的跳转----to表示跳转到哪里去,tag表示是什么标签

<div id="app">
    <router-view></router-view>
    <router-link to="/home" tag="li"></router-link>
    <router-link to="/list" tag="li"></router-link>
</div>

 

路由跳转的方式:

  1、a标签进行跳转----<a href="#/home">首页</a>

  2、router-link进行跳转----<router-link to="/home" tag="li">首页</router-link>

      当路由配置成功后,VueRouter会提供2个内置组件来做组件的显示:<router-view></router-view>----路由组件展示    <router-link to="/home" tag="a"></router-link>----路由的跳转(to表示到达的地方,tag表示渲染成什么标签)

  3、编程式路由----this.$router.back()----this.$router.push()----这两个最终要

      在created函数中this是VueComponent对象,这些方法都是原型中的方法

      this.$router.back()  后退

      this.$router.forward()  前进---一般不用

      this.$router.push()  跳转

      this.$router.go()  指定跳转---1表示前景,-1表示后退,0表示刷新

      this.$router.replace()  替换

 

路由传值的方式:

  1、动态路由传值

    例如:path:"/home/:id/name";  接受的时候通过 this.$route.params

    ①定义路由时,通过/:属性/:属性来定义传递的属性

    ②路由跳转时,通过/值/值将数据传到对应的组件中

    ③在对应的组件内部通过this.$route.params进行数据的接收

  2、query传值。因为在url中?后面的参数不会被解析,因此我们可以通过query进行传值。接收的时候通过 this.$route.query

  3、路由解耦。在配置路由的时候添加props属性为true,在需要接受参数的组件页面通过props进行接受

  4、编程式导航  this.$router.push({path:"/home",query:{}});

 

动态路由传值和query传值的区别:(是否需要传递参数)

  动态路由中path:"/detail/:id/:name"----前端路由跳转时必须要传递参数,如果没有参数,那么对应的页面不会显示。

  query中path:"/detail"----query传值时不需要写参数。

 

路由配置项常用的属性及作用:

  路由配置参数:

    mode:hash----默认,地址栏中有#号,不需要后端配置,建议使用;history----地址栏中没有#号,需要后端配置。

    path:跳转路径

    component:路径相对于的组件

    name:命名路由----在path:"/home"后面加一个name:"home",用于动态路由传值时以对象的形式传值

    meta:路由元信息

    children:子路由的配置参数(路由嵌套)

    props:路由解耦----在配置项中增加props:true

    redirect:重定向路由

 

编程式导航使用的方法以及常用的方法:

  路由跳转:this.$router.push()

  路由替换:this.$router.replace()

  后退:this.$router.back()

  前进:this.$router.forward()

  指定跳转:this.$router.go()

 

如何重定向路由?

  配置路由中的redirect进行重定向

 

如何实现路由解耦?

  在路由的配置项中设置props:true,在需要接受组件的内部通过props进行接受

 

$router和$toute的区别:

  $route:当前路由的信息,fullPath、hash、matched、meta、params、path、query

  $router:路由的实例对象,具有一些需要的方法,如编程式导航的跳转

 

路由守卫:

  路由钩子函数,路由跳转前的一些验证。

  全局守卫:beforeEach----实例VueRouter的方法,在index.js中用router调用。(局部守卫在各个页面中写在export default{ }中)

    router.beforeEach((to,from,next)=>{
        document.title=to.meta.title;
        if(to.path!="/login" && to.meta.auth){
            if(sessionStorage.getItem("token")){
                next();
            }else{
                next("/login");
            }
        }else{
            next();
        }
    });

 

  局部守卫:

    beforeRouteEnter:进入路由前的守卫,当前路由的钩子函数中访问不到this。

    场景:登录验证、热力图、权限校验、消息通知

 

    beforeRouteEnter(to,from,next){
        //这里无法获取this
        //to---去哪里   from---从哪里来    next()---跳转
        next("/login");
        next((vw)=>{//vw---VueComponent对象

        });
    }

 

    beforeRouteUpdate:路由更新时的守卫,当路由发生改变时,而当前组件没有经历创建和销毁时就需要用到beforeRouteUpdate。

 

    //当点击orderdetail页面的水果切换时,地址栏更新而页面不更新,解决:
    beforeRouteUpdate(to,from,next){
        this.id=to.params.id;
        this.name=to.params.name;
        next();
    }

 

    除此之外,watch监听$route的变化也能达到同样的效果。

    watch: {
        "$route"(to,from){
            this.id=to.params.id;
            this.name=to.params.name;
        }   
    }

 

    beforeRouteLeave:路由离开时的守卫

    场景:未支付、未保存、答题系统、退出登录

 

    beforeRouteLeave(to,from,next){
        let flag=confirm("确定要离开吗?");
        if(flag) next();
    }

 

 

 

路由懒加载:

  1、异步组件的方式

  2、ES6的import的方式

    

 

posted @ 2019-07-28 01:15  吴小明-  阅读(1477)  评论(0编辑  收藏  举报