2.6Java全栈开发前端+后端(全栈工程师进阶之路)-前端框架VUE3-基础-Vue生命周期

news/2025/1/16 0:01:13/

在使用vue进行日常开发中,我们总有这样的需求,想在页面刚一加载出这个表格组件时,就发送请求去后台拉取

数据,亦或者想在组件加载前显示个loading图,当组件加载出来就让这个loading图消失等等这样或那样的需求。

要实现这些需求,最重要的一点就是我怎么知道这个组件什么时候加载,换句话说我该什么时候向后台发送请求,

为了解决这种问题,组件的生命周期钩子函数就应运而生。

Vue生命周期图示

下面这张图,就是Vue官网给我们展示的Vue生命周期图:

这是官方文档给出的一个组件从被创建出来到最后被销毁所要经历的一系列过程,所以这个过程也叫做一个组件的

生命周期图。从图中我们可以看到,一个组件从被创建到最后被销毁,总共要经历以下8个过程:

  1. beforeCreate: 实例创建之前

  2. created:实例创建完毕

  3. beforeMount:DOM挂载之前

  4. mounted:DOM挂载完毕

  5. beforeUpate:数据更新之前

  6. updated:数据更新完毕

  7. beforeUnmount:解除DOM挂载之前

  8. unmounted:解除DOM挂载完毕

 注意:在使用 Composition API形式时,beforeCreate与created生命周期使用setup()来实现。在后面的课 程中会详细介绍setup()方法。

代码演示 

<div id="app"><mycomponent v-if="isShow"></mycomponent><button @click="change">隐藏</button>
</div>
<script src="../js/vue3.js"></script>
<script>const app = Vue.createApp({data(){return {isShow: true}},methods:{change(){this.isShow = !this.isShow;}}});app.component('mycomponent',{template: `<div>{{num}} <button @click="add" id="btn">加</button></div>`,data(){return {num: 10}},methods:{add(){this.num++;}},beforeCreate(){console.log('beforeCreate - Vue实例创建前的生命周期函数');},created(){console.log('created - Vue实例创建后的生命周期函数');},beforeMount(){console.log('beforeMount - Vue实例挂载DOM前的生命周期函数');},mounted(){let btnObj = document.getElementById('btn');console.log(btnObj);console.log('mounted - Vue实例挂载DOM后的生命周期函数');},beforeUpdate(){console.log('beforeUpdate - Vue实例数据更新前的生命周期函数');},updated(){console.log('updated - Vue实例数据更新后的生命周期函数');},beforeUnmount(){console.log('beforeUnmount - Vue实例卸载前的生命周期函数');},unmounted(){console.log('unmounted - Vue实例卸载后的生命周期函数');}});app.mount('#app');
</script>

上面实例中,使用 v-if 来卸载组件,这样就可以演示beforeUnmount与unmounted生命周期。

总结

以上就是vue中组件生命周期钩子函数执行的各个过程以及执行的时机,但是这些钩子函数到底该怎么用呢?针对

前言中提出的需求我们又该怎么解决呢?在这里,给大家举个例子:

例如有一个表格组件:

  1. 我们想在表格加载之前显示个loading图,那么我们可以在组件实例创建之前的钩子函数setup里面将

loading图显示。

  1. 当组件实例加载出来,我们可以在created钩子函数里让这个loading图消失。

  2. 当表格被加载好之后我们想让它马上去拉取后台数据,那么我们可以在组件DOM挂载之前的钩子函数

beforeMount里面去发送请求。

  1. 从后台拉取的数据要绑定在DOM中,那么就必须要在组件DOM挂载完毕的钩子函数mounted里面去

做。

  1. 表格中的数据在更新前和更新后,我们都需要做一个处理,那么这些工作就可以放在beforeUpdate和

updated中去做。

  1. 当应用程序结束后,或组件实例准备销毁时,有一些善后处理的工作(比如释放资源)就可以放在

beforeUnmount和unmounted中去做。

在Vue中操作DOM

通过前面的学习,我们知道:使用Vue之后,由于有数据双向绑定机制,我们就不必直接操作DOM来绑定数据了。

但是我们仍然有可能在实战中去操作DOM。比如:做一些图片轮播等页面特效时,就必须要直接操作DOM。

所以,Vue给我们提供了一套机制,让我们直接操作DOM。这样,我们就可以不必使用

document.getElementById() 这些原生javascript代码了。

 

<div id="app"><mycomponent v-if="isShow"></mycomponent><button @click="change">隐藏</button>
</div>
<script src="../js/vue3.js"></script>
<script>const app = Vue.createApp({data(){return {isShow: true}},methods:{change(){this.isShow = !this.isShow;}}});app.component('mycomponent',{template: `<div>{{num}} <button @click="add" ref="btn">加</button></div>`,data(){return {num: 10}},methods:{add(){this.num++;}},beforeCreate(){console.log('beforeCreate - Vue实例创建前的生命周期函数');},created(){console.log('created - Vue实例创建后的生命周期函数');},beforeMount(){console.log('beforeMount - Vue实例挂载DOM前的生命周期函数');},mounted(){let domObj = this.$refs.btn;//console.log(domObj);domObj.style.color = 'red';console.log('mounted - Vue实例挂载DOM后的生命周期函数');},beforeUpdate(){console.log('beforeUpdate - Vue实例数据更新前的生命周期函数');},updated(){console.log('updated - Vue实例数据更新后的生命周期函数');},beforeUnmount(){console.log('beforeUnmount - Vue实例卸载前的生命周期函数');},unmounted(){console.log('unmounted - Vue实例卸载后的生命周期函数');}});app.mount('#app');
</script>

先在需要获取的DOM节点中添加 ref属性。

在 mounted 生命周期中使用 this.$refs.username 的形式来获取DOM

注意:数据绑定时不要直接操作DOM,而是要使用数据双向绑定。只有在非数据绑定时,才可以去直接操作

DOM。


http://www.ppmy.cn/news/1458937.html

相关文章

探索数字社交的奇迹:解读Facebook的革命性影响

1. 社交互动的全新模式 Facebook的出现不仅仅是一个社交媒体平台的诞生&#xff0c;更是一种全新的社交互动模式的开启。传统的社交模式主要依赖于面对面的交流&#xff0c;而Facebook则将社交推向了全新的数字化平台&#xff0c;使得人们可以在虚拟的世界里建立和维系社交关系…

phpmyadmin配置文件权限错误

错误信息 配置文件权限错误,不应任何用户都能修改! 解决办法 找到phpmyadmin所在目录 给phpmyadmin目录授权755 chmod -R 755 phpmyadmin验证服务是否可以正常访问

IDEA 使用maven编译,控制台出现乱码问题的解决方式

前言 使用idea进行maven项目的编译时&#xff0c;控制台输出中文的时候出现乱码的情况。 通常出现这样的问题&#xff0c;都是因为编码格式不一样导致的。既然是maven出的问题&#xff0c;我们在idea中查找下看可以如何设置文件编码。 第一种方式 在pom.xml文件中&#xff…

引入RabbitMQ

前置条件 docker 安装 mq docker run \-e RABBITMQ_DEFAULT_USERdudu \-e RABBITMQ_DEFAULT_PASS123456 \-v mq-plugins:/plugins \--name mq \--hostname mq \-p 15672:15672 \-p 5672:5672 \--network hmall \-d \rabbitmq:3.8-management可能会出现&#xff1a;docker: Er…

嵌入式学习——51单片机——(流水灯、数码管)day16

1. 位运算在单片机中的使用 & : 按位与 &#xff08;与0得0、与1不变&#xff09;&#xff08;全1为1&#xff0c;有0得0&#xff09;指定位置0 1. 让一个字节第n位&#xff08;从右往左第n位&#xff09;置0 P0 & ~(1 << n); 2. 让一个字节第n位&#xff08;…

win32操作windows应用(未完成)

win32 脚本制作 一 、获取窗口句柄 首先获取句柄&#xff0c;其次扫描组件&#xff0c;然后对按钮和文本进行操作 安装依赖 pip install pywin32 -i https://pypi.doubanio.com/simple扫描全部的句柄 import win32gui# GetDesktopWindow 获得代表整个屏幕的一个窗口&#…

政务热线系统让政府服务更接地气

一、引言 随着社会的快速发展和民众需求的日益增长&#xff0c;政府面临着巨大的挑战。政府需要更好地倾听民众的声音&#xff0c;关注民众的关切&#xff0c;并采取相应的措施回应民众的需求。而政府热线系统作为一种重要的沟通渠道&#xff0c;在提升政府服务质量、增强政府…

Spring Boot集成Ldap快速入门Demo

1.Ldap介绍 LDAP&#xff0c;Lightweight Directory Access Protocol&#xff0c;轻量级目录访问协议. LDAP是一种特殊的服务器&#xff0c;可以存储数据数据的存储是目录形式的&#xff0c;或者可以理解为树状结构&#xff08;一层套一层&#xff09;一般存储关于用户、用户…