Vue生命周期

图解

文字讲解

beforeCreate

初始化界面前.

这个时候只是一个空的Vue()对象 , 并且只有默认的生命周期函数和默认事件.

<body>
    <div id="app">
        <div id="divId">页面还没有渲染 --- {{msg}}</div>
    </div>

    <script>
        var vue = new Vue({
            el: "#app",
            data: {
                msg: "页面渲染完毕"
            },
            methods: {

            },
            filters: {

            },
            beforeCreate() {
                // 这是我们第一个遇到的生命周期函数,实例被创建出来,
                // 还没有data、methods等时,会执行它
                let content = document.getElementById('divId')
                console.log('beforeCreate:', content.innerText)
                // 在js中,null和undefined是不同的含义。null表示有这个对象,
                // 但是这个对象的值是null。undefined表示压根就没有这个对象
                console.log('beforeCreate', this.msg)
            }
        })
    </script>
</body>

image-20200325221055247

create

初始化界面后

这时的data和method已经被初始化完成.

<body>
    <div id="app">
        <div id="divId">页面还没有渲染 --- {{msg}}</div>
    </div>

    <script>
        var vue = new Vue({
            el: "#app",
            data: {
                msg: "页面渲染完毕"
            },
            methods: {

            },
            filters: {

            },
            created() {
                // 这是我们第一个遇到的生命周期函数,实例被创建出来,
                // 还没有data、methods等时,会执行它
                let content = document.getElementById('divId')
                console.log('beforeCreate:', content.innerText)
                // 在js中,null和undefined是不同的含义。null表示有这个对象,
                // 但是这个对象的值是null。undefined表示压根就没有这个对象
                console.log('beforeCreate', this.msg)
            }
        })
    </script>
</body>

image-20200325221253610

beforMount

渲染dom前

这时模板已经在内存中编译完成 , 但没有加载到页面中去.

<body>
    <div id="app">
        <div id="divId">页面还没有渲染 --- {{msg}}</div>
    </div>

    <script>
        var vue = new Vue({
            el: "#app",
            data: {
                msg: "页面渲染完毕"
            },
            methods: {

            },
            filters: {

            },
            beforeMount() {
                // Vue实例创建完毕,页面尚未重新渲染
                let content = document.getElementById('divId')
                console.log('beforeMounte', content.innerText)
                console.log('beforeMounte', this.msg)
            }
        })
    </script>
</body>

image-20200325221427466

mounted

dom渲染后

这时的页面编译并且替换完毕.

<body>
    <div id="app">
        <div id="divId">页面还没有渲染 --- {{msg}}</div>
    </div>

    <script>
        var vue = new Vue({
            el: "#app",
            data: {
                msg: "页面渲染完毕"
            },
            methods: {

            },
            filters: {

            },
            mounted() {
                // 页面渲染完毕
                let content = document.getElementById('divId')
                console.log('mounted', content.innerText)
                console.log('mounted', this.msg)
            }
        })
    </script>
</body>

image-20200325221551881

beforeUpdate

更新数据前

当data数据被修改后会进行触发

update

更新数据后

当update被执行到的时候 , 页面中的数据已经和data保持同步

beforeDestroy

卸载组件前

这时Vue的实例已经从运行阶段变成了销毁阶段. 而这时实例身上所有的data , methods , 过滤器 , 指令都处于可用状态

destroyed

卸载组件后

这是Vue的所有组件都不可用了

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小源同学r

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值