VUE 实例的生命周期

什么是VUE生命周期

从Vue实例创建、运行、到销毁期间,总是伴随着各种各样的事件,这些事件,统称为生命周期!
vue把整个生命周期划分为 创建 、更新、挂载、销毁 等阶段

生命周期钩子

其实就是生命周期事件的 别名

生命周期函数分类

  • 创建期间的生命周期函数:
    1.beforeCreate:实例刚在内存中被创建出来,还没有初始化好 data 和methods属性
    data 和 el 还不可用
    2 create:实例已经在内存中创建OK
    data可以用,但是el 的值为undefined

  • 挂载期间的生命周期函数
    1 beforeMound:此时已经完成了模板的编译,但是还没有挂载到页面中
    2 mounted: 此时已经将编译好的模板 挂载到了页面指定的容器中显示

  • 更新期间的生命周期函数:
    1.beforeUpdate:状态更新之前执行此函数,此时data中的状态值是最新的,但是界面上显示的数据还是旧的,因为这个时候还没有开始重新渲染DOM节点
    2 .updated:实例更新完毕之后调用此函数,此时data中的状态值和界面上显示的数据都已经完成了更新,界面已经被重新渲染好了!

  • 销毁期间的生命周期函数:
    1.beforeDestroy: 实例销毁之前调用,
    2 .Vue实例销毁后调用,调用后,Vue实例指示的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁
    在这里插入图片描述
    下面学习各个生命周期阶段

  • beforedCreate
<script>
    var vm = new Vue({
      el: '#app',
      data: {},
      methods: {},
      beforeCreate() {
        console.log('即将创建');
        console.log(this.$el);
        console.log(this.$data);

      }
    });
  </script>

结果:
在这里插入图片描述
!我们可以看到 data 和el 还是不可用的

  • Created(成功创建)

beforeCreate之后紧接着的钩子就是创建完毕created,我们同样打印一下数据data和挂载元素el,看会得到什么?

<script>
    var vm = new Vue({
      el: '#app',
      data: {
	name:'赫于富'
},
      methods: {},
      created() {
        console.log('即将创建');
        console.log(this.$el);
        console.log(this.$data);

      }
    });
  </script>

结果:
在这里插入图片描述
我们可以看到 ,这个时候我们已经可以读取data的数,但是DOM没有生成,el的值还是没有的

  • beforeMount(挂载之前)
    上一个阶段我们知道DOM还没生成,属性el还为undefined,那么,此阶段为即将挂载,我们打印一下此时的$el是什么?
<script>
    var vm = new Vue({
      el: '#app',
      data: {
      	name:'赫于富'},
      methods: {},
      beforeMount() {
        console.log('即将创建');
        console.log(this.$el);
        console.log(this.$data);

      }
    });
  </script>

结果:
在这里插入图片描述
现在已经成功创建了DOM节点,但是{{name}}还没有成功渲染到我们的页面

  • mounted(成功挂载)

在这里插入图片描述
在这里插入图片描述
如我们所愿,此时打印属性el,我们看到{{ name }}已经成功渲染成我们data.name的值

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值