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

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

liuian 2024-12-14 13:33 158 浏览

作者 | 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、代码:

<div id="box">
<ul>
<li v-for="item in list" :key="item.id">{{item.name}}</li>
</ul>
</div>
<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:

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

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

1、beforeMount与mounted实例①:

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

<div id="box">
<div ref='demo'>demo</div>
</div>
<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实例②:

<div id="box">
<div ref='demo'>demo</div>
</div>
<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实例③:

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

<div id="box">
<input type="text" ref='txt'>
</div>
<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执行顺序差别演示:

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

<div id="box"></div>
<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:

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

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

注意:

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

例:beforeUpdate与updated执行演示:

<body>
<div id="box">
<input type="range" min="1" max="100" v-model="n" />
<Com :n="n"></Com>
</div>
<script>
var Com = {
props:["n"],
template: `<div>{{n}}</div>`,
//这两个钩子会在数据更新时被调用
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()可以销毁组件)

<div id="box">
<Com></Com>
</div>
<script>
var Com = {
template: `<div>
<button @click="kill">kill</button>
</div>`,
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执行演示:

<div id="box">
<keep-alive>
<component :is="cName"></component>
</keep-alive>
<button @click="cName='One'">change1</button>
<button @click="cName='Two'">change2</button>
</div>
<script>
var One ={
template:`<div>one component</div>`,
activated{
console.log("activated");
},
deactivated{
console.log("deactivated");
}
}
var Two ={
template:`<div>two component</div>`,
}
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

?尤雨溪:重头来过的 Vue 3 带来了什么?

?活跃了 40 年的 AWK 现在怎么样了?

?可怕!CPU 竟成了黑客的帮凶!

?如何用NLP辅助投资分析?三大海外机构落地案例详解

?这 10 个云计算错误,会让你的业务一蹶不振!

?好扑科技结合区块链行业发展趋势,重磅推出“好扑区块链合伙人”计划

相关推荐

驱动网卡(怎么从新驱动网卡)
驱动网卡(怎么从新驱动网卡)

网卡一般是指为电脑主机提供有线无线网络功能的适配器。而网卡驱动指的就是电脑连接识别这些网卡型号的桥梁。网卡只有打上了网卡驱动才能正常使用。并不是说所有的网卡一插到电脑上面就能进行数据传输了,他都需要里面芯片组的驱动文件才能支持他进行数据传输...

2026-01-30 00:37 liuian

win10更新助手装系统(微软win10更新助手)

1、点击首页“系统升级”的按钮,给出弹框,告诉用户需要上传IMEI码才能使用升级服务。同时给出同意和取消按钮。华为手机助手2、点击同意,则进入到“系统升级”功能华为手机助手华为手机助手3、在检测界面,...

windows11专业版密钥最新(windows11专业版激活码永久)

 Windows11专业版的正版密钥,我们是对windows的激活所必备的工具。该密钥我们可以通过微软商城或者通过计算机的硬件供应商去购买获得。获得了windows11专业版的正版密钥后,我...

手机删过的软件恢复(手机删除过的软件怎么恢复)
手机删过的软件恢复(手机删除过的软件怎么恢复)

操作步骤:1、首先,我们需要先打开手机。然后在许多图标中找到带有[文件管理]文本的图标,然后单击“文件管理”进入页面。2、进入页面后,我们将在顶部看到一行文本:手机,最新信息,文档,视频,图片,音乐,收藏,最后是我们正在寻找的[更多],单击...

2026-01-29 23:55 liuian

一键ghost手动备份系统步骤(一键ghost 备份)

  步骤1、首先把装有一键GHOST装系统的U盘插在电脑上,然后打开电脑马上按F2或DEL键入BIOS界面,然后就选择BOOT打USDHDD模式选择好,然后按F10键保存,电脑就会马上重启。  步骤...

怎么创建局域网(怎么创建局域网打游戏)

  1、购买路由器一台。进入路由器把dhcp功能打开  2、购买一台交换机。从路由器lan端口拉出一条网线查到交换机的任意一个端口上。  3、两台以上电脑。从交换机任意端口拉出网线插到电脑上(电脑设置...

精灵驱动器官方下载(精灵驱动手机版下载)

是的。驱动精灵是一款集驱动管理和硬件检测于一体的、专业级的驱动管理和维护工具。驱动精灵为用户提供驱动备份、恢复、安装、删除、在线更新等实用功能。1、全新驱动精灵2012引擎,大幅提升硬件和驱动辨识能力...

一键还原系统步骤(一键还原系统有哪些)

1、首先需要下载安装一下Windows一键还原程序,在安装程序窗口中,点击“下一步”,弹出“用户许可协议”窗口,选择“我同意该许可协议的条款”,并点击“下一步”。  2、在弹出的“准备安装”窗口中,可...

电脑加速器哪个好(电脑加速器哪款好)

我认为pp加速器最好用,飞速土豆太懒,急速酷六根本不工作。pp加速器什么网页都加速,太任劳任怨了!以上是个人观点,具体性能请自己试。ps:我家电脑性能很好。迅游加速盒子是可以加速电脑的。因为有过之...

任何u盘都可以做启动盘吗(u盘必须做成启动盘才能装系统吗)

是的,需要注意,U盘的大小要在4G以上,最好是8G以上,因为启动盘里面需要装系统,内存小的话,不能用来安装系统。内存卡或者U盘或者移动硬盘都可以用来做启动盘安装系统。普通的U盘就可以,不过最好U盘...

u盘怎么恢复文件(u盘文件恢复的方法)

开360安全卫士,点击上面的“功能大全”。点击文件恢复然后点击“数据”下的“文件恢复”功能。选择驱动接着选择需要恢复的驱动,选择接入的U盘。点击开始扫描选好就点击中间的“开始扫描”,开始扫描U盘数据。...

系统虚拟内存太低怎么办(系统虚拟内存占用过高什么原因)

1.检查系统虚拟内存使用情况,如果发现有大量的空闲内存,可以尝试释放一些不必要的进程,以释放内存空间。2.如果系统虚拟内存使用率较高,可以尝试增加系统虚拟内存的大小,以便更多的应用程序可以使用更多...

剪贴板权限设置方法(剪贴板访问权限)
剪贴板权限设置方法(剪贴板访问权限)

1、首先打开iphone手机,触碰并按住单词或图像直到显示选择选项。2、其次,然后选取“拷贝”或“剪贴板”。3、勾选需要的“权限”,最后选择开启,即可完成苹果剪贴板权限设置。仅参考1.打开苹果手机设置按钮,点击【通用】。2.点击【键盘】,再...

2026-01-29 21:37 liuian

平板系统重装大师(平板重装win系统)

如果你的平板开不了机,但可以连接上电脑,那就能好办,楼主下载安装个平板刷机王到你的个人电脑上,然后连接你的平板,平板刷机王会自动识别你的平板,平板刷机王上有你平板的我刷机包,楼主点击下载一个,下载完成...

联想官网售后服务网点(联想官网售后服务热线)

联想3c服务中心是联想旗下的官方售后,是基于互联网O2O模式开发的全新服务平台。可以为终端用户提供多品牌手机、电脑以及其他3C类产品的维修、保养和保险服务。根据客户需求层次,联想服务针对个人及家庭客户...