生命周期函数

vue生命周期钩子
=生命周期函数
=生命周期事件
与EL DATA METHODS 平级
创建阶段的4个生命周期

  beforeCreate(){//表示刚初始化了一个Vue空的实例对象,这时候,这个对象身上,只有默认的
            //一些生命周期函数和默认的事件,其它的东西都未创建
            //在beforeCreate生命周期函数执行的时候,data和methods中的数据都还没有初始化
            /*console.log(this.msg)
            this.show()*/
            //this.msg  undefined
            /*cannot find prototype show*/
        },
        created(){//第二个生命周期函数
            console.log(this.msg);
            this.show();
            //在created中, data和methods都已经初始化好了
            //如果要调用methods中的方法 或者 data中的数据 最早只能在created中操作
        },
        beforeMount(){//第三个生命周期函数 表示模板已经加载完成。但是还没有渲染到页面上
           // console.log(document.getElementById("h3").innerText)// {{msg}}
            //在beforeMount执行的时候,页面中的元素。还没有真正替换过来。值是之前写的一些模板字符串
        },
        mounted(){//第四个生命周期函数 表示 内存中的模板已经真是的挂载到了页面中,用户
            //已经可以看到渲染之后的页面
            console.log(document.getElementById("h3").innerText)
        }

如果要通过某些插件 操作页面上的DOM节点 最早要在mounted中进行
只要执行忘了mounted 就表示整个VUE实例 已经初始化完毕

组件运行阶段的生命周期函数

beforeUpadate(){}
upadated(){}
beforeMount(){//第三个生命周期函数 表示模板已经加载完成。但是还没有渲染到页面上
           // console.log(document.getElementById("h3").innerText)// {{msg}}
            //在beforeMount执行的时候,页面中的元素。还没有真正替换过来。值是之前写的一些模板字符串
        },
        mounted(){//第四个生命周期函数 表示 内存中的模板已经真是的挂载到了页面中,用户
            //已经可以看到渲染之后的页面
           // console.log(document.getElementById("h3").innerText)
        },

这两事件 会根据 data数据的改变 ,有选择性的触发 0 次 到多次

当数据进行更新的时候, 先根据data中最新的数据, 在内存中。重新渲染出一份最新的 内存DOM树 重新渲染到真实的页面中去, 这时候,就完成了数据 从 data(model层)->view (视图层) 的变化

当新的DOM树更新完成之后,还没有渲染到页面之前 会执行beforeUpdate钩子函数
当真实页面渲染成功之后,就会执行updated函数

当执行beforeDestroy的时候 Vue实例已经从运行阶段 进行到了销毁阶段,但是实例身上所有的methods,以及过滤器 指令... 都处于可用状态 此时 还没有真正执行销毁的过程

当执行到destroyed函数的时候,组件已经完全被销毁了 此时, 组件中所有的数据,方法,指令, 过滤器,所有的东西都已经不可用了

beforeDestroy(){}
destroyed(){}

完整代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="js/vue.js"></script>
</head>
<body>
<div id="app">
    <input type="button" value="修改msg" @click="msg='No'">
    <h3 id="h3">{{msg}}</h3>
</div>
</body>
<script>
    var vm=new Vue({
        el:"#app",
        data:{
            msg:'OK'
        },
        methods:{
            show(){
                console.log("执行了show方法");
            }
        },
        beforeCreate(){//表示刚初始化了一个Vue空的实例对象,这时候,这个对象身上,只有默认的
            //一些生命周期函数和默认的事件,其它的东西都未创建
            //在beforeCreate生命周期函数执行的时候,data和methods中的数据都还没有初始化
            /*console.log(this.msg)
            this.show()*/
            //this.msg  undefined
            /*cannot find prototype show*/
        },
        created(){//第二个生命周期函数
           // console.log(this.msg);
           // this.show();
            //在created中, data和methods都已经初始化好了
            //如果要调用methods中的方法 或者 data中的数据 最早只能在created中操作
        },
        beforeMount(){//第三个生命周期函数 表示模板已经加载完成。但是还没有渲染到页面上
           // console.log(document.getElementById("h3").innerText)// {{msg}}
            //在beforeMount执行的时候,页面中的元素。还没有真正替换过来。值是之前写的一些模板字符串
        },
        mounted(){//第四个生命周期函数 表示 内存中的模板已经真是的挂载到了页面中,用户
            //已经可以看到渲染之后的页面
           // console.log(document.getElementById("h3").innerText)
        },
        beforeUpdate(){//这时候, 表示 我们的界面还有没有更新【数据 已经被更新了】
           // console.log(document.getElementById("h3").innerText)
           // console.log('data中的数据是'+this.msg)//当执行beforeUpdate的时候 页面中显示的
            //数据还是旧的,此时 Data数据是最新的 页面尚未和最新的数据保持同步
        },
        updated(){
            console.log(document.getElementById("h3").innerText)
            console.log('data中的数据是'+this.msg)
        }
    })
</script>
</html>
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 先看完函数介绍,在看下面的生命周期函数图示把 beforeCreate 第一个生命周期函数,表示实例完全被创建出来...
    IT小池阅读 907评论 0 13
  • react中生命周期函数主要分为三个阶段 1.创建阶段 2.运行阶段 3.销毁阶段 创建阶段:创建阶段经过的五个小...
    修齐治平zzr阅读 5,999评论 0 3
  • 一:什么是闭包?闭包的用处? (1)闭包就是能够读取其他函数内部变量的函数。在本质上,闭包就 是将函数内部和函数外...
    xuguibin阅读 9,750评论 1 52
  • # 传智播客vue 学习## 1. 什么是 Vue.js* Vue 开发手机 APP 需要借助于 Weex* Vu...
    再见天才阅读 3,629评论 0 6
  • 我是水 晶莹透明,温文尔雅是我的常态 喜欢淙淙流淌唱着动听的歌 从那高山之巅顺着...
    楚梦云阅读 587评论 6 12