Vue生命周期钩子

本文深入探讨了Vue.js实例的生命周期,包括beforeCreate、created、beforeMount、mounted、beforeUpdate、updated、beforeDestroy和destroyed等钩子函数。通过示例代码展示了在不同生命周期阶段执行的操作,如事件绑定和DOM操作。了解这些生命周期有助于更好地控制和管理Vue应用的状态和行为。

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

<body>
    <div id="app">
            <p>{{msg}}</p>
            <div>
                <input type="button" value="更新" @click="change">
                <input type="button" value="销毁" @click="destory">
                <input type="button" value="点点看" id="btn">
            </div>
    </div>
</body>
<script>
    new Vue({
        el:"#app",
        data() {
            return {
                msg:"实例消息"
            }
        },
        // 钩子函数(生命周期函数)
        // 1.创建之前
        beforeCreate() {
            alert("创建实例之前")
        },
        // 2.创建之后
        created() {
            alert("创建实例完成")
            // 创建完成但没有挂载,猜猜可以出来吗(出不来)
            let btn = document.querySelector("#btn");
            btn.onclick = function(){
                alert("111哈哈出来了")
            }

        },
        // 3.挂载之前
        beforeMount() {
            alert("实例挂载前")
        },
        // 4.挂载之后
        mounted() {
            alert("实例挂载完成")
            let btn = document.querySelector("#btn");
            // 挂载之后才可以出来
            btn.onclick = function(){
                alert("666哈哈出来了")
            }

        },
        // 5.更新之前
        beforeUpdate() {
            alert("更新前")
        },
        // 6.更新之后
        updated() {
            alert("更新后")
        },
        // 7.销毁之前
        beforeDestroy() {
            alert("销毁前");
        },
        // 8.销毁之后
        destroyed() {
            alert("销毁完成")
        },
        methods: {
            change(){
                this.msg = "更新成功";
            },
            destory(){
                this.$destroy();
            }
        },
    })
</script>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值