Vue的生命周期

103 阅读1分钟

Vue的生命周期:

一个Vue实例从创建到销毁的整个过程

创建阶段的最后发送初始化渲染的请求(越早越好) 挂载阶段的最后可以开始操作dom()至少dom得渲染出来

Vue的生命周期函数(钩子函数)

Vue生命周期过程中,会自动运行一些函数,被称为生命周期钩子 ->让开发者可以在特定阶段运行自己的代码。

image.png

钩子函数的实例

<div id="app">
    <h3>{{ title }}</h3>
    <div>
      <button @click="count--">-</button>
      <span>{{ count }}</span>
      <button @click="count++">+</button>
    </div>
  </div>
const app = new Vue({
      el: '#app',
      data: {
        count: 100,
        title: '计数器'
      },
      // 1.创建阶段(准备数据)
      beforeCreate(){
        console.log('',this.count); // undefined
      },
      created(){
        console.log('',this.count); // 100
        // this.数据名=请求回来的数据
        // 可以开始发送初始化渲染的请求了
      },
      //2.挂载阶段(渲染模版)
      beforeMount(){
        console.log('',document.querySelector('h3').innerHTML);
      }, // beforeMount 模板渲染之前 {{ title }}
      mounted(){
        console.log('',document.querySelector('h3').innerHTML); // mounted 模板渲染之后 计数器
        //可以开始操作dom了
      },
      //3.更新阶段(修改数据 ->更新视图)
      beforeUpdate(){
        console.log('数据修改了,视图没更新',document.querySelector('span').innerHTML);
      }, // beforeUpdate 数据修改了,视图还没更新, 100
      Update(){
        console.log('数据修改了,视图也更新了',document.querySelector('span').innerHTML);
      }, // updated 数据修改了,视图已经更新, 101
      //4.卸载阶段
      beforeDestroy(){
        console.log('beforeDestroy,卸载前');
        console.log('清除掉一些Vue以外的资源占用,定时器,延时器...');
      },
      destroy(){
        console.log('destroyed,卸载后');
      }     
    })