• 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>

    右侧打赏一下 代码改变世界一块二块也是爱
  • 相关阅读:
    数据挖掘专业术语
    Python 随机数用法
    精通Web Analytics 2.0 (8) 第六章:使用定性数据解答”为什么“的谜团
    建模前的数据清洗/ETL(python)
    [分类算法] :朴素贝叶斯 NaiveBayes
    DSP, SSP, DMP
    laravel路由
    Laravel 5 中的配置
    Jquery的each遍历数据组成JSON
    JS上传图片预览及图片限制
  • 原文地址:https://www.cnblogs.com/ht955/p/14237067.html
Copyright © 2020-2023  润新知