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

    每个 Vue 实例在被创建之前都要经过一系列的初始化过程。例如需要设置数据监听、编译模板、挂载实例到 DOM、在数据变化时更新 DOM 等。同时在这个过程中也会运行一些叫做生命周期钩子的函数,给予用户机会在一些特定的场景下添加他们自己的代码。

    beforeCreate

    在实例初始化之后,数据观测和事件配置之前被调用 此时data methods 以及页面的DOM结构都没有初始化 什么都做不了

    created

    在实例创建完成后被立即调用此时data methods已经可以使用 但是页面还没有渲染出来

    beforeMount

    在挂载开始之前被调用 此时页面上还看不到真实数据 只是一个模板页面而已

    mounted

    el被新创建的vm.$el替换,并挂载到实例上去之后调用该钩子。 数据已经真实渲染到页面上 在这个钩子函数里面可以进行数据请求等

    beforeUpdate

    数据更新时调用,页面上数据还是旧的

    updated

    由于数据更新完毕,页面上数据已经替换成最新的

    beforeDestroy

    实例销毁之前调用

    destroyed

    实例销毁后调用

    <div id="root">

    <input type="text" v-model="title">

    </div>

     

    <script src="./js/vue.js"></script>

    <script>

      new Vue({

        el: '#root',

        data: {

          title: '我是一个标题',

          timer: null

        },

        // 初始化之前,不可以读取datamethods中的值和方法  只调用一次

        beforeCreate() {

          // location.href = 'http://www.baidu.com'

          // this只是一个没有数据的代理的 vue对象

          console.log('beforeCreate', this)

        },

        // 初始化  可以读取datamethods中的值和方法  只调用一次

        created() {

          // 延时器

          this.timer = setTimeout(() => {

            // 主动让组件销毁

            this.$destroy()

          }, 3000)

          console.log('created', this.title)

        },

        // 组件挂载完成之前

        beforeMount() {

          console.log('beforeMount')

        },

        // 挂载完毕,数据渲染完毕  一般在于写 网络请求

        mounted() {

          console.log('mounted')

        },

        // data中数据更新之前

        beforeUpdate() {

          console.log('beforeUpdate')

        },

        // data中数据更新之后

        updated() {

          console.log('updated')

        },

        // 销毁之前  计时器,延时器  如果此组件中有,可以在销毁之有,把这些动画全清了 clearInterval

        beforeDestroy() {

          console.log('beforeDestroy')

          clearTimeout(this.timer)

        },

        destroyed() {

          console.log('destroyed')

        }

      })

    </script>

    右侧打赏一下 代码改变世界一块二块也是爱
  • 相关阅读:
    封装异常处理之坑
    30multipart/form-data和application/x-www-form-urlencoded的区别(二)urlencoded之自动deocde
    使用MAT时的Shallow Size和 Retained Size的区别
    当动态代理遇到ioc
    线程池的原理
    synchroned原理与对象头(yet)
    mysql压力测试与qps监控
    一种mysql jvm死锁
    Android Jni变量对照表
    结构体中使用函数指针
  • 原文地址:https://www.cnblogs.com/ht955/p/14237067.html
Copyright © 2011-2022 走看看