zoukankan      html  css  js  c++  java
  • vue-router中vue生命周期的顺序

    1. vue-router 在 Vue 中的生命周期:

    这是 vue 生命周期的图:

    在路由中分别定义A页面和B页面

    A页面:

    <template>
      <div>
        <router-link to="/test2">去B页面</router-link>
      </div>
    </template>
    
    <script>
      export default {
        beforeCreate(){
          console.log('A页面 beforeCreate');
        },
        created(){
          console.log('A页面 created');
        },
        mounted(){
          console.log('A页面 mounted');
        },
        beforeDestroy(){
          console.log('A页面 beforeDestroy');
        },
        destroyed(){
          console.log('A页面 destroyed');
        }
      }
    </script>

    B页面:

    <template>
      <div>
        <router-link to="/test1">去A页面</router-link>
      </div>
    </template>
    
    <script>
      export default {
        beforeCreate(){
          console.log('B页面 beforeCreate');
        },
        created(){
          console.log('B页面 created');
        },
        mounted(){
          console.log('B页面 mounted');
        },
        beforeDestroy(){
          console.log('B页面 beforeDestroy');
        },
        destroyed(){
          console.log('B页面 destroyed');
        }
      }
    </script>

    从 A 页面跳到 B 页面:

    2. Vue-Router中,导航守卫的执行顺序:

     这里存在疑惑的是组件的生命周期到底在导航守卫的哪个阶段执行,测试代码如下:

    结论:从控制台结果可以看出,组件的生命周期是在Vue-Router导航守卫的DOM更新过程中执行的

    1. 导航被触发。
    2. 在失活的组件里调用离开守卫。
    3. 调用全局的 beforeEach 守卫。
    4. 在重用的组件里调用 beforeRouteUpdate 守卫 (2.2+)。
    5. 在路由配置里调用 beforeEnter
    6. 解析异步路由组件。
    7. 在被激活的组件里调用 beforeRouteEnter
    8. 调用全局的 beforeResolve 守卫 (2.5+)。
    9. 导航被确认。
    10. 调用全局的 afterEach 钩子。
    11. 触发 DOM 更新。(此过程触发组件的生命周期)
    12. 用创建好的实例调用 beforeRouteEnter 守卫中传给 next 的回调函数。

     这也就解释了切换路由时,两个组件生命周期执行的顺序是交叉的。

  • 相关阅读:
    [转]《三国演义》人名英文翻译妙评 你也来评评!
    Effective C++:改善程序技术与设计思维的55个有效做法(第三版)(中文版)(预订)Effective C++ 3RD
    A Closer Look At Parallax Occlusion Mapping
    [转]收录全部作品,《寂静岭套装》发售开始
    [转]程序员版《桃花庵》
    Cg 1.5 Beta 2
    FilteredTextBox控件
    CollapsiblePanel控件
    DynamicPopulate控件
    HoverMenu控件的使用
  • 原文地址:https://www.cnblogs.com/momo798/p/13580434.html
Copyright © 2011-2022 走看看