zoukankan      html  css  js  c++  java
  • 浅谈对路由的理解

    什么是路由?

      根据不同的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的方式

        

  • 相关阅读:
    gps示例代码
    UART 串口示例代码
    Linux soft lockup 和 hard lockup
    Linux嵌入式kgdb调试环境搭建
    Linux嵌入式GDB调试环境搭建
    Linux-workqueue讲解
    USB之hub3
    USB之设备插入波形变化2
    我运营公众号这一个月
    从12306帐号泄漏谈用户密码安全
  • 原文地址:https://www.cnblogs.com/wuqilang/p/11257509.html
Copyright © 2011-2022 走看看