vue生命周期图解

在这里插入图片描述
vue生命周期共有8个函数

var app = new Vue({
      el: '#app',
      data: {
        message: 'hello',
        value: '123',
        list: [] //[1,2,3,4]
      },
      // template: `
      //     <div id="app" class="two">
      //       <h1>{{message}}</h1>
      //     </div>
      // `,
      computed: {

      },
      watch: {
        message(){
          this.$nextTick(()=>{
            console.log('nextTick......');
          });
        }
      },
      methods: {
        testAction(){
      
        },
        modifyAction(){
        
        },
        modifyValueAction(){
        
        }
      },
      beforeCreate(){
      
      },
      created(){
      
      },
      beforeMount(){
      
      },
      mounted(){
        // 这个方法之后,可以操作dom
        // 但是不要使用document
        // 使用$refs
      },
      beforeUpdate(){
      
      },
      updated(){
      
      },
      beforeDestroy(){
      
      },
      destroyed(){
      
      }
    });
  • 创建和挂载阶段

    1. new Vue();
    2. 加载生命周期函数
    3. 调用beforeCreate(),这个阶段无法使用数据,方法,dom操作。
    4. 读取vue示例的配置项。加载数据方法,监听…
    5. 调用created();
    6. 判断是否有el配置项 , 如果没有,则等待$mount()执行获得el;
    7. 判断是否有template配置项,没有则使用el.outerHTML当成template;
    8. 调用render函数 , 渲染dom。
    9. 调用brforeMount()。
    10. 使用渲染好的template替换el。
    11. 调用mounted() , 此时vue示例可以开始使用了。
  • 更新阶段

    1. 当数据已经发生变化,数据监听回调被调起。
    2. 如果dom使用了该属性,调用beforeUpdate()。
    3. 重新渲染dom。
    4. 调用updated()。
    5. 调用$nextTick() , 监听具体有什么原因导致dom更新的。
  • 销毁阶段

    1. 当实例调用$destroy() .
    2. beforeDestroy() 移除监听 ,移除外部对实力内部的引用。
    3. vue实例内部产生的引用和监听也会移除。(vue内部自动完成)。
    4. 调用destroy()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值