zoukankan      html  css  js  c++  java
  • vue.js生命周期

    Vue实例的生命周期

    Vue实例有一个完整的生命周期,也就是从开始创建、初始化数据、编译模板、挂载Dom、渲染→更新→渲染、卸载等一系列过程,我们称这是Vue的生命周期。通俗说就是Vue实例从创建到销毁的过程,就是生命周期。

    Vue提供的可以注册的钩子都在上图片的红色框标注。 他们是:

    • beforeCreate

    在实例初始化之后,数据观测(data observer) 和 event/watcher 事件配置之前被调用。

    • created

    实例已经创建完成之后被调用。在这一步,实例已完成以下的配置:数据观测(data observer),属性和方法的运算, watch/event 事件回调。然而,挂载阶段还没开始,$el 属性目前不可见。

    • beforeMount

    在挂载开始之前被调用:相关的 render 函数首次被调用。

    • mounted

    el 被新创建的 vm.$el 替换,并挂载到实例上去之后调用该钩子。如果 root 实例挂载了一个文档内元素,当 mounted 被调用时 vm.$el 也在文档内。

    • beforeUpdate

    数据更新时调用,发生在虚拟 DOM 重新渲染和打补丁之前。 你可以在这个钩子中进一步地更改状态,这不会触发附加的重渲染过程。

    • updated

    由于数据更改导致的虚拟 DOM 重新渲染和打补丁,在这之后会调用该钩子。

    当这个钩子被调用时,组件 DOM 已经更新,所以你现在可以执行依赖于 DOM 的操作。然而在大多数情况下,你应该避免在此期间更改状态,因为这可能会导致更新无限循环。

    该钩子在服务器端渲染期间不被调用。

    • beforeDestroy

    实例销毁之前调用。在这一步,实例仍然完全可用。

    • destroyed

    Vue 实例销毁后调用。调用后,Vue 实例指示的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁。 该钩子在服务器端渲染期间不被调用。

    接下来我们做一个例子,看一下Vue中所有的生命周期怎么用的。

     1 <!DOCTYPE html> 
     2 <html lang="en">
     3 <head>
     4   <meta charset="UTF-8">
     5   <title>Vue入门之生命周期</title>
     6   <script src="https://unpkg.com/vue/dist/vue.js"></script>
     7 </head>
     8 <body>
     9   <div id="app">
    10     <p>{{ number }}</p>
    11     <input type="text" name="btnSetNumber" v-model="number">
    12   </div>
    13   <script>
    14     var app = new Vue({         
    15       el: '#app',               
    16       data: {                   
    17         number: 1
    18       },
    19       beforeCreate: function () {
    20         console.log('beforeCreate 钩子执行...');
    21         console.log(this.number)
    22       },
    23       cteated: function () {
    24         console.log('cteated 钩子执行...');
    25         console.log(this.number)
    26       },
    27       beforeMount: function () {
    28         console.log('beforeMount 钩子执行...');
    29         console.log(this.number)
    30       },
    31       mounted: function () {
    32         console.log('mounted 钩子执行...');
    33         console.log(this.number)
    34       },
    35       beforeUpdate: function () {
    36         console.log('beforeUpdate 钩子执行...');
    37         console.log(this.number)
    38       },
    39       updated: function () {
    40         console.log('updated 钩子执行...');
    41         console.log(this.number)
    42       },
    43       beforeDestroy: function () {
    44         console.log('beforeDestroy 钩子执行...');
    45         console.log(this.number)
    46       },
    47       destroyed: function () {
    48         console.log('destroyed 钩子执行...');
    49         console.log(this.number)
    50       },
    51     });
    52   </script>
    53 </body>
    54 </html>

    结果

    请使用手机"扫一扫"x

    若有恒,何须三更睡五更起;最无益,莫过于一日曝十日寒
  • 相关阅读:
    Python 去掉文本中空行
    Pandas常用操作方法
    Numpy常用操作方法
    Python获取指定路径下所有文件的绝对路径
    Python获取指定目录下所有子目录、所有文件名
    Pycharm选中代码无法Backspace直接删除
    Redis常用命令(一)
    在eclipse程序中设置的断点上有一个斜杠,正常启动debug不能够跳转到debug页面,怎么解决
    常见的几种网络广告模式
    struts2中拦截器与过滤器的区别
  • 原文地址:https://www.cnblogs.com/21haoxingxiu/p/7265438.html
Copyright © 2011-2022 走看看