登录  /  注册
首页 > web前端 > js教程 > 正文

如何理解vue中的生命周期(钩子函数)

清浅
发布: 2019-04-18 15:57:38
原创
39316人浏览过

vue生命周期(钩子函数)表示的是vue实例对象从开始创建到销毁的过程。vue生命周期钩子函数其实就是vue实例的选项,这些选项的值全部都是函数,代表了该实例从出生到死亡这一生当中的各阶段,只要达到该阶段就会自动触发。

如何理解vue中的生命周期(钩子函数)

【推荐课程:Vue教程

Vue的生命周期指的是什么?

Vue的生命周期通俗来讲就是我们用Vue写的网页在浏览器运行起来之后,我们写的代码要在内存里执行。例如我们都会写的var vm = new Vue();,就是new出来了一个Vue 实例。这个实例从创建一直到我们关掉浏览器这个实例消亡,这一段时间里,Vue这个框架干了啥,Vue的实例做了啥,先做啥,后做啥,这一系列事情的关系是怎样的,这就是Vue的生命周期。

Vue的生命周期分三个阶段:创建阶段,运行阶段,销毁阶段。

在图中,我对生命周期各个部分进行了标注并做了一些必要的解释。

如何理解vue中的生命周期(钩子函数)

流程解释(12步对应图中操作):

1、生成一个Vue实例,执行钩子函数beforeCreate()。【实例创建前】

2、对实例进行初始化。

3、把实例成员挂载到view model身上,执行钩子函数created()。【实例创建后】

4、判断有无el对象【el对象用来指明我们控制的视图是那一区域】。

5、如果有el对象,判断是否使用了模板。

6、如果使用了模板,则按照编译模板的方法去做,如果没有则把el控制的视图区域当做模板来渲染。执行钩子函数beforeMount()。【实例挂载前】

7、把经过更改的新的el视图区域,替换掉原来的el视图区域。执行钩子函数Mounted()【实例挂载后】。

8、进入运行阶段,运行阶段就是进行一些操作了,执行钩子函数beforeUpdate()。【数据更新前】

9、操作完毕之后,把这些数据渲染到页面上,执行钩子函数updated()。【数据更新后】

10、进入销毁阶段,执行钩子函数beforeDestroy()【实例销毁前】

11、进行销毁,拆卸监视器、子组件和事件侦听器。

12、销毁完成,执行钩子函数destroyed()。【实例销毁后】

  • 生命周期中的钩子函数是Vue在它生命周期中必须要执行到的事件,这些事件其实就是函数。

  • 当然这些事件是允许我们程序员来编写代码的,以此当Vue的生命周期走到这里时,来进行我们想要的操作。

  • 一个实例在创建阶段和销毁阶段的六个钩子函数是永远执行一次的。执行过去了,就不会再次执行了。

在图中提到:在Vue的生命周期执行完init Events之后我们才能访问我们定义的实例成员,并且这个点也是最早可以访问到实例成员的点,为了验证这个,我们看一段代码。

<body>
    <div id="app"></div>
    //这里的路径为本机上的vue.js路径
    <script src="./lib/vue.js"></script>
    <script>
        var vm = new Vue({
            el : &#39;#app&#39;,
            data : {
                msg : &#39;我是初始值&#39;
            },
            methods : {
                show : function(){
                    console.log(this.msg);
                }
            },
            beforeCreate(){
                console.log(this.msg);
            },
            created(){
                console.log(this.msg);
            }
        });
    </script>
</body>
登录后复制

结果如图:

如何理解vue中的生命周期(钩子函数)

可以看到在beforeCreate()的时候,我们输出的是undefined,而在 created()后就输出了msg的值。

这说明在Vue的实例成员是在created之后,才挂载到了我们的vm身上,所以在created之后再访问就能访问到我们的实例成员了。

以上就是如何理解vue中的生命周期(钩子函数)的详细内容,更多请关注php中文网其它相关文章!

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号