iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >VUE生命周期全面系统详解
  • 867
分享到

VUE生命周期全面系统详解

2024-04-02 19:04:59 867人浏览 安东尼
摘要

目录什么是生命周期生命周期的作用Vue生命周期有哪些Vue 生命周期总共分为几个阶段1)beforeCreate创建前2)created创建后3)beforeMounte挂载前4)m

什么是生命周期

每个组件在被创建时都要经过一系列的初始化过程——例如,需要设置数据监听、编译模板、将实例挂载到 DOM 并在数据变化时更新 DOM 等。同时在这个过程中也会运行一些叫做生命周期钩子的函数

生命周期的作用

  • 创建后发起axax请求
  • 挂载后操作dom
  • 添加事件监听
  • 销毁前移除间隔调用,事件监听
  • 说明:并不是每个生命周期都必须使用

vue生命周期有哪些

如下图(记不住就抄八百遍)

Vue 生命周期总共分为几个阶段

Vue 实例从创建到销毁的过程,就是生命周期。也就是从开始创建、初始化 数据、编译模板、挂载 Dom→渲染、更新→渲染、卸载等一系列过程,我们称这 是 Vue 的生命周期。

创建前后

1)beforeCreate创建前

在实例初始化之后,数据观测 (data observer) 和 event/watcher 事件配 置之前被调用。

特点: 有this,没有data,methods,dom节点

beforeCreate() {
			// 创建前,有this,没有data,methods,dom节点
			console.log("beforeCreate",this.num ,this)
		},

2)created创建后

在实例创建完成后被立即调用。在这一步,实例已完成以下的配置:数据观 测 (data observer), 属性和方法的运算,watch/event 事件回调。然而,挂 载阶段还没开始,$el 属性目前不可见。

特点:有this,没有$els,dom节点

用处:发起ajax请求,开启定时器,监听事件(window)

created() {
			// 创建完毕,有data,没有el
			console.log("created",this.num ,this.$el)
			// 作用发起ajax请求,开启定时器,监听事件(window)
			// 开启定时器
			this.stopId = setInterval(() => {
				this.num++;
				console.log("滴答")
			}, 1000)
			// 监听事件
			window.addEventListener("resize",this.showWin)
		},

挂载前后

3)beforeMounte挂载前

特点: 有$el,没有渲染数据

在挂载开始之前被调用:相关的 render 函数首次被调用。

		beforeMount() {
			// dom挂载前,有el,没有渲染数据
			// beforeMount 访问&el 为什么是 undefined
			// 因为使用的脚手架,动态更新造成的(在非脚手架状态下可以)
			console.log("beforeMount", this, document.querySelector("#btn"))
		},

4)mounted挂载后

特点: 有dom节点,数据也渲染

用处: 操作dom节点,发起ajax请求,开启定时器,监听事件, el 被新创建的 vm.$el 替换,并挂载到实例上去之后调用该钩子。如果 root 实例挂载了一个文档内元素,当 mounted 被调用时 vm.$el 也在文档内。

		mounted() {
			// 挂载完毕
			console.log("*mounted", this, document.querySelector("#btn"))
			// this 当前组件的实例
			// this.$el 当前组件的dom节点
			// this.num当前组件的 属性
			// console.log(this,this.$el,"组件的实例this",this.num)
			// 作用:作用发起ajax请求,开启定时器,监听事件,操作dom节点
		},

更新前后

5)beforeUpdate更新前

特点: 会执行多次,数据更新,dom节点没有更新

数据更新时调用,发生在虚拟 DOM 打补丁之前。这里适合在更新之前访问 现有的 DOM,比如手动移除已添加的事件监听器。该钩子在服务器端渲染期间不 被调用,因为只有初次渲染会在服务端进行。

		// 更新前后
		beforeUpdate() {
			// 组件的更新前,数据更新,视图没有更新
			console.log("beforeUpdate", this.num, document.querySelector("#btn").innerText)
		},

6)updated更新后

特点: 会执行多次,数据更新,dom节点也更新

由于数据更改导致的虚拟 DOM 重新渲染和打补丁,在这之后会调用该钩子。

		updated() {
			// 组件更新后,数据更新,视图已经更新
			console.log("updated", this.num, document.querySelector("#btn").innerText)
		},

销毁前后

7)beforeDestroy销毁前

特点: 数据更新,视图没有更新

用处:移除事件监听,停止计时器

实例销毁之前调用。在这一步,实例仍然完全可用。该钩子在服务器端渲染 期间不被调用。

		// 卸载前后
		beforeDestroy() {
			// 结束定时器
			clearInterval(this.stopId);
			//移除事件监听
			window.removeEventListener("resize", this.showWin)
			// 数据可以更新,视图已经不响应
			// this.num++;
			// console.log( "卸载前","beforeDestroy")
			// alert("卸载前")
		},

8)destroyed销毁后

特点: 没有this,切换视图与vue实例的联系

Vue 实例销毁后调用。调用后,Vue 实例指示的所有东西都会解绑定,所有 的事件监听器会被移除,所有的子实例也会被销毁。该钩子在服务器端渲染期间 不被调用。

		destroyed() {
			// 切断视图与vue实例的联系
			// this.num++;
			console.log("卸载后", "destroyed")
		}

效果如下:

问题

第一次加载页面会触发哪几个钩子函数?

当页面第一次页面加载时会触发 beforeCreate, created, beforeMount, mounted 这几个钩子函数

到此这篇关于VUE生命周期全面系统详解的文章就介绍到这了,更多相关VUE生命周期内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: VUE生命周期全面系统详解

本文链接: https://www.lsjlt.com/news/165609.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • VUE生命周期全面系统详解
    目录什么是生命周期生命周期的作用vue生命周期有哪些Vue 生命周期总共分为几个阶段1)beforeCreate创建前2)created创建后3)beforeMounte挂载前4)m...
    99+
    2024-04-02
  • Vue生命周期详解
    这篇博客将会从下面四个常见的应用诠释组件的生命周期,以及各个生命周期应该干什么事 单组件的生命周期父子组件的生命周期兄弟组件的生命周期宏mixin的生命周期 生命周期:Vue 实例从...
    99+
    2024-04-02
  • 详解vue生命周期
    目录为什么要理解生命周期什么是生命周期生命周期钩子函数created和mounted钩子的一些实战用法1.异步函数 2.Vue.nextTick对异步函数的结果进行操作 总结为什么要...
    99+
    2024-04-02
  • Vue生命周期区别详解
    生命周期分类 vue每个组件都是独立的,每个组件都有一个属于它的生命周期, 从一个组件创建、数据初始化、挂载、更新、销毁,这就是一个组件所谓的生命周期。 在组件中具体的方法有: ...
    99+
    2024-04-02
  • 微信APP生命周期及页面生命周期示例详解
    目录官方文档小程序的启动流程app生命周期页面的生命周期页面的生命周期(图)官方文档 ogram&jumpbackUrl=%2Fdoc%2F" rel="external n...
    99+
    2024-04-02
  • Vue之生命周期函数详解
    目录生命周期函数常用的生命周期的钩子 关于Vue销毁实例: 总结 生命周期函数 生命周期函数又叫:生命周期回调函数,生命周期函数、 生命周期钩子 是什么:Vue在关键时刻帮我们调用...
    99+
    2024-04-02
  • 全面详解Spring Bean生命周期教程示例
    目录Spring 中 Bean 的生命周期Bean 的实例化构造方法注入工厂方法注入Bean 的属性赋值setter注入构造方法注入Bean 的初始化初始化方法Initializin...
    99+
    2023-05-14
    Spring Bean生命周期 Spring Bean
  • vue的生命周期钩子与父子组件的生命周期详解
    目录vue的生命周期钩子的介绍父子组件的生命周期加载渲染过程父组件更新过程子组件更新过程父子组件更新过程销毁过程代码示例created和mounted的区别vue的生命周期钩子的介绍...
    99+
    2022-11-13
    vue 生命周期 vue 父子组件生命周期
  • 详解Vue生命周期和MVVM框架
    目录生命周期与动态组件有关的两个特殊的钩子:与组件异常捕获有关的一个钩子:生命周期有哪些生命周期 组件从开始到结束的全过程 创建阶段:beforeCreate、created挂载阶段...
    99+
    2024-04-02
  • Vue生命周期与setup深入详解
    目录生命周期生命周期函数不同API的生命周期setup介绍1. 访问Props2. setup上下文3. 与渲染函数一起使用生命周期 下图对比了vue3(左)和vue2(右)的生命周...
    99+
    2024-04-02
  • rust生命周期详解
    目录rust生命周期借用检查函数中的生命周期手动声明生命周期结构体中的生命周期生命周期消除三条消除原则生命周期约束静态生命周期rust生命周期 生命周期是rust中用来规定引用的有效...
    99+
    2023-03-19
    rust生命周期
  • Vue 生命周期和数据共享详解
    目录1.组件的生命周期1.1生命周期与生命周期函数 1.2组件生命周期函数的分类1.3生命周期图示以及详解2.组件之间的数据共享2.1组件之间的关系2.2父向子传值2.3子...
    99+
    2024-04-02
  • Vue组件与生命周期详细讲解
    目录写在前面生命周期图解总结写在前面 Vue.js的核心就是以简洁的模板语法将数据渲染进Dom系统。vue实例在渲染成html的时候往往要经过以下的步骤: 读取数据和方法,设置数据绑...
    99+
    2022-11-13
    Vue组件 Vue生命周期
  • 详解uniapp的生命周期
    Uniapp作为一款跨平台应用开发框架,具有丰富的生命周期,以下是Uniapp的生命周期: 1.应用生命周期 应用生命周期是指应用程序从启动到关闭的整个过程,包括应用程序的启动、前后...
    99+
    2023-05-17
    vue uniapp uniapp生命周期
  • React的生命周期详解
    一、React生命周期 React 生命周期分为三种状态 1. 初始化2.更新3.销毁 初始化 1、getDefaultProps() 设置默认的props,也可以用dufault...
    99+
    2024-04-02
  • Vue生命周期怎么理解
    这篇“Vue生命周期怎么理解”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue生命周期怎么理解”文章吧。1、定义生命周期函...
    99+
    2023-07-06
  • React中的生命周期详解
    目录react生命周期常用的生命周期不常用的生命周完整的生命周期图react生命周期 函数组件无生命周期,生命周期只有类组件才拥有 生命周期函数指在某一时刻组件会自动调用并执行的函数...
    99+
    2024-04-02
  • 微信APP生命周期及页面生命周期是什么
    本篇内容介绍了“微信APP生命周期及页面生命周期是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!小程序的启动流程我们画一个图来表示一下,...
    99+
    2023-06-30
  • Vue生命周期介绍和钩子函数详解
    目录Vue生命周期介绍和钩子函数 VUE生命周期钩子 Vue生命周期简介 create 和 mounted 相关 update 相关 destroy 相关 总结 Vue生命周期介绍和...
    99+
    2024-04-02
  • 浅谈vue的生命周期
    目录1.什么是生命周期有什么作用2.第一次加载页面会触发哪几个钩子3.简述每个周期应用于哪个场景4.created和mounted的区别5.vue在哪个生命周期获取数据总结1.什么是...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作