百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

不来看看这些 VUE 的生命周期钩子函数?| 原力计划

myzbx 2025-03-23 21:37 11 浏览

作者 | huangfuyk

责编 | 王晓曼

出品 | CSDN 博客

VUE的生命周期钩子函数:就是指在一个组件从创建到销毁的过程自动执行的函数,包含组件的变化。可以分为:创建、挂载、更新、销毁四个模块。

注:在组件的整个生命周期内,钩子函数都是可被自动调用的,且生命周期函数的执行顺序与书写的顺序无关。

图示:

BeforeCreate

该函数执行在组件创建、数据观测 (data observer) 和 event/watcher 事件配置之前,实例初始化之后被调用。

在该阶段组件未创建,不能访问数据,组件中的 data,ref 均为 undefined。

Created

该函数在组件创建完成后被立即调用,在这一步,实例已完成以下的配置:数据观测 (data observer),属性和方法的运算,watch/event 事件回调。

但是还未渲染成HTML模板,组件中的data对象已经存在,可以对data进行操作了,即可以访问数据,发请求,ref依旧是undefined,挂载阶段还没开始,$el 属性目前尚不可用。

一般我们可以将对数据的初始化和初始化页面的请求放到里面,结束loading。

Created 实例:1、RAP2 模拟一个后端接口(
http://rap2.taobao.org:38080/app/mock/252122/test),使用 created 拿数据。

2、RAP2操作界面如下:

3、代码:

Bash
{{item.name}}<script>new Vue({el:"#box",data:{list:},created{fetch('http://rap2.taobao.org:38080/app/mock/252122/test').then(res=>res.json).then((res)=>{if(res.code===200){this.list = res.data.list;}})},beforeCreate{},})</script>

4、结果

BeforeMount

该函数在组件挂载之前,在该阶段页面上还没渲染出 HTML 元素,data 初始化完成,ref 依旧不可以操作,相关的 render 函数首次被调用。

可以访问数据,编译模板结束,虚拟 dom 已经存在。

该钩子在服务器端渲染期间不被调用。

Mounted

该函数是页面完成挂载之后执行的,这时 el 被新创建的 vm.$el 替换了,就可以操作 ref 了,一般会用于将组件初始时请求数据的方法放到这里面,filter 也是在这里生效。

如果根实例挂载到了一个文档内的元素上,当 mounted 被调用时 vm.$el 也在文档内。

可以拿到数据和节点,实例被挂载后调用。

注意 :mounted 不会保证所有的子组件也都一起被挂载。如果你希望等到整个视图都渲染完毕,可以在 mounted 内部使用 vm.$nextTick:

Bash
mounted: function  {this.$nextTick(function {// Code that will run only after the// entire view has been rendered})}

该钩子在服务器端渲染期间不被调用。

1、beforeMount与mounted实例①:

(ref表示节点;this.$refs.ref的标识,就可拿到节点)

Bash
demo<script>new Vue({el:"#box",data:{a:666},mounted{console.log('mounted',this.a);},beforeMount{console.log('beforeMount',this.a);console.log(this.$refs.demo);}})</script>

结果:

2、beforeMount与mounted实例②:

Bash
demo<script>new Vue({el:"#box",data:{a:666},mounted{console.log('mounted',this.a);console.log(this.$refs.demo);},beforeMount{console.log('beforeMount',this.a);}})</script>

结果:

3、beforeMount与mounted实例③:

(节点挂载后,文本框自动获取焦点)

Bash
<script>new Vue({el:"#box",data:{a:666,},mounted{console.log('mounted',this.a);this.$refs.txt.focus;},beforeMount{console.log('beforeMount',this.a);}})</script>

结果:

以上两个实例,更加有力的说明:

beforeMount执行在真实的dom节点挂载之前,此时没有节点,所以拿不到节点。mounted执行时真实的dom节点已经挂载到页面上了,所以能拿到节点。

例:beforeCreate、created、beforeMount、mounted执行顺序差别演示:

(因为 它们此时都是对象,所以它们代码的摆放位置是不影响结果的。)

Bash
<script>new Vue({el:"#box",data:{a:666,},created{console.log("created",this.a);},beforeCreate{console.log('beforeCreate',this.a);},mounted{console.log('mounted',this.a);},beforeMount{console.log('beforeMount',this.a);}})</script>

结果:

BeforeUpdate

该函数在数据更新时调用,发生在虚拟 DOM 打补丁之前,在有特殊需求的情况下,可以将更新之前的数据存起来,放到后面去使用。

这里适合在更新之前访问现有的 DOM,比如手动移除已添加的事件监听器。

该钩子在服务器端渲染期间不被调用,因为只有初次渲染会在服务端进行。

Updated

由于数据更改导致的虚拟 DOM 重新渲染和打补丁,在这之后会调用该钩子,在数据更新之后做一些处理,即监控数据的变化。

当这个钩子被调用时,组件 DOM 已经更新,所以你现在可以执行依赖于 DOM 的操作。然而在大多数情况下,你应该避免在此期间更改状态。如果要相应状态改变,通常最好使用计算属性或 watcher 取而代之。

注意 :updated 不会保证所有的子组件也都一起被重绘。如果你希望等到整个视图都重绘完毕,可以在 updated 里使用 vm.$nextTick:

Bash
updated: function  {this.$nextTick(function {// Code that will run only after the// entire view has been re-rendered})}

该钩子在服务器端渲染期间不被调用。

注意:

watch是监控特定数据的变化,而updated是监控组件里所有数据的变化。

例:beforeUpdate与updated执行演示:

Bash
<script>var Com = {props:["n"],template: `{{n}}`,//这两个钩子会在数据更新时被调用beforeUpdate{console.log("beforeUpdate")},updated{console.log("updated")}};new Vue({el: '#box',components: {Com,},data:{n:1}});</script>

结果:

BeforeDestroy

该函数在实例销毁之前调用,这里的 ref 依旧可以操作,实例仍然完全可用,可以在这里做清除定时器的操作,防止内存泄漏。

该钩子在服务器端渲染期间不被调用。

Destroyed

该函数在组件销毁的时候执行,即实例销毁后调用,这里的 ref 不存在。

该钩子被调用后,对应 Vue 实例的所有指令都被解绑,所有的事件监听器被移除,所有的子实例也都被销毁。

该钩子在服务器端渲染期间不被调用。

例:beforeDestroy与destroyed执行演示:

(this.$destroy()可以销毁组件)

Bash
<script>var Com = {template: `kill`,mounted {this.timer = setInterval(=>{console.log("hello");},1000)},beforeDestroy{clearInterval(this.timer);console.log("beforeDestory")},destroyed{console.log("destoryed")},methods:{kill{ //销毁组件this.$destroy}}};new Vue({el: '#box',components: {Com,},});</script>

结果:

注:组件进行销毁的时候,是先销毁的是父组件,然后销毁子组件。

Activated

被 keep-alive 缓存的组件激活时调用。

该钩子在服务器端渲染期间不被调用。

Deactivated

被 keep-alive 缓存的组件停用时调用。

该钩子在服务器端渲染期间不被调用。

例:activated与deactivated执行演示:

Bash
change1change2<script>var One ={template:`one component`,activated{console.log("activated");},deactivated{console.log("deactivated");}}var Two ={template:`two component`,}new Vue({el:"#box",components:{One,Two},data:{cName:'One' //存组件的名字}})</script>

结果:

ErrorCaptured

类型:(err: Error, vm: Component, info: string) => ?boolean。

当捕获一个来自子孙组件的错误时被调用。此钩子会收到三个参数:错误对象、发生错误的组件实例以及一个包含错误来源信息的字符串。此钩子可以返回 false 以阻止该错误继续向上传播。

我们可以在此钩子中修改组件的状态。因此在捕获错误时,在模板或渲染函数中有一个条件判断来绕过其它内容就很重要;不然该组件可能会进入一个无限的渲染循环。

  • 默认情况下,如果全局的 config.errorHandler 被定义,所有的错误仍会发送它,因此这些错误仍然会向单一的分析服务的地方进行汇报。

  • 如果一个组件的继承或父级从属链路中存在多个 errorCaptured 钩子,则它们将会被相同的错误逐个唤起。

  • 如果此 errorCaptured 钩子自身抛出了一个错误,则这个新错误和原本被捕获的错误都会发送给全局的config.errorHandler。

  • 一个 errorCaptured 钩子能够返回 false以阻止错误继续向上传播。本质上是说“这个错误已经被搞定了且应该被忽略”。它会阻止其它任何会被这个错误唤起的 errorCaptured钩子和全局的 config.errorHandler。

版权声明:本文为CSDN博主「huangfuyk」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:
https://blog.csdn.net/weixin_42881768/article/details/105747563

Bash
尤雨溪:重头来过的 Vue 3 带来了什么?活跃了 40 年的 AWK 现在怎么样了?可怕!CPU 竟成了黑客的帮凶!如何用NLP辅助投资分析?三大海外机构落地案例详解这 10 个云计算错误,会让你的业务一蹶不振!好扑科技结合区块链行业发展趋势,重磅推出“好扑区块链合伙人”计划

相关推荐

一步一步往上爬 可爱像素跳跃《Cuby Jump》

CliqersSdnBhd宣布旗下新作《CubyJump》已经正式在全球的iOS及Android双平台上架。该作是一款像素风格的跳跃游戏,玩家要控制萌萌哒的各种角色跃过险阻到达顶峰。玩家必须操控...

Apex英雄手游版上手实测:“味对了”,但瑜不掩瑕

大家好呀,这里是你们的小编。《Apex英雄》近日在菲律宾开启了小范围Beta测试。小编也是费尽心思,终于能够上手体验这款《Apex英雄》的手游版啦!先给出一个结论:有端游的感觉,但是还不够。《Apex...

《古墓丽影崛起》高空滑索怎么转换?高空滑索技巧分享

在《古墓丽影崛起》中,要完成高空滑索转换并解锁“滑索专家”奖杯,玩家需要掌握一定的技巧和时机。以下是一些具体的步骤和建议:一、高空滑索转换技巧芭芭雅嘎打女巫场景:在游戏中,芭芭雅嘎打女巫的场景是完成高...

第一人称跑酷游戏FOTONICA:急速奔跑的超快感

一款第一人称跑酷游戏,3年前已登陆PC端,以其绝妙的几何抽象艺术画面吸引了玩家们的目光。今夏登陆iOS平台,在原版的基础上增加了新的曲目和关卡,光怪陆离的跑酷场景不断刺激你的双眼。想玩好,首先要有...

点击类休闲游戏《跳转战士》 在跳跃中寻求厮杀快感

寿司发表于2015-12-2417:52以不断砍杀怪物从而获得经验和奖励的游戏可谓十分常见,不过近日推出的这款休闲游戏JumpWarrior《跳转战士》却采用了不断跳跃的方式来进行游玩。在这款...

FC游戏《冒险岛》1234通关结局赏析,多少玩家被卡了整整三十年

《冒险岛》系列应该是所有玩家们的共同回忆吧!就是不知道当年的你接触过哪一代呢?《冒险岛》在红白机平台发行了四部作品,在街机平台有一款名为《神奇小子》的游戏和《冒险岛》很有渊源,这在之前我们已经仔细研究...

452,跳跃游戏

给定一个非负整数数组,你最初位于数组的第一个位置。数组中的每个元素代表你在该位置可以跳跃的最大长度。判断你是否能够到达最后一个位置。示例1:输入:[2,3,1,1,4]输出:true解释:我们...

休闲游戏《跳跃山羊》:简单跳跃填色带你回温经典

Laficko发表于2015-12-0515:33经典街机游戏《Q伯特》凭借着颇具立体感的画面效果以及简单的填色玩法,在过去80年代便受到不少玩家的喜爱。如今开发商ATOOI按照这款经典...

游戏百解——跳一跳(Python自动跳跃)

跳一跳Python游戏百解。今天将教大家怎么用Python程序做一个跳一跳这个游戏的辅助工具,在后续将加入图像识别算法,让小人可以自动识别并跳到下个平台。·首先得确定两个平台之间的距离,做了一个简单的...

《幻塔》战斗体系解析:浮空闪避,动作体验如何丝滑?

前言相较于武侠、仙侠、魔幻题材而言,提起科幻类型的游戏,大部分人都会在脑海里浮现出“硬核”、“烧脑”等一系列足以劝退萌新小白的形容词。正因如此,怎样深入浅出地讲好一个科幻故事,探讨科技与人性的关系,也...

《电精》和《电神魔傀》的无敌隐身,街机游戏中的上帝模式

估计很多玩家都还分不清楚《电精》和《电神魔傀》这两款游戏吧!简单一点来说的话,《电精》就是三人版,来自SFC平台。而《电神魔傀》则是六人版,来自街机平台。当年我们在街机游戏厅中玩到的几乎都是《电精》,...

3D平台跳跃游戏《蓝精灵:梦境》发布首支预告:2024年底推出

IT之家4月29日消息,发行商Microids今日发布了3D平台跳跃游戏《蓝精灵:梦境》的首支预告。目前游戏Steam商店页面已经上线,游戏支持单人游玩,或与一名好友组队双人游玩...

黏液 - 评测:小巧有趣的平台跳跃冒险游戏

与自家的整洁程度有所不同,我反倒发现在游戏中完成清洁工作有种莫名的满足感。正因如此,《黏液(TheGunk)》对我来说有着别样的吸引力,因为它的线性战役为我提供了这样的机会,将一个被黏液覆盖的外星球...

魔兽怀旧服:熊坦跳跃的时候无躲闪?深入研究6条原理,涨知识了

一位魔兽世界TBC怀旧服的熊坦玩家在打团的时候被队友吐槽了,队友认为他的游戏习惯不好,经常跳跃导致滞空时间过长会没有躲闪。这个队友的建议让熊坦一脸懵,跳跃无躲闪这个说法他还是第一次听到,那么这位队友的...

“趣游戏”唤醒两代人的童年!课间15分钟已悄然升级到“PLUS版本”

为了响应省教育厅“2·15”专项行动的要求,新学期开学以来,南京江北新区高新实验小学的课间延长到了15分钟。如何让延长的课间既安全有序又充满活力?该校开展了校园达人“封绳榜”挑战赛,用一根小小的跳绳,...