文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何理解Vue生命周期和钩子函数

2023-06-25 12:08

关注

这期内容当中小编将会给大家带来有关如何理解Vue生命周期和钩子函数,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

1. vue生命周期

一组件从 创建 到 销毁 的整个过程就是生命周期

如何理解Vue生命周期和钩子函数

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

2.钩子函数

Vue 框架内置函数,随着组件的生命周期阶段,自动执行,特定的时间点,执行特定的操作

2.1 分为4大阶段8个方法:

阶段方法名方法名
初始化beforeCreatedcreated
挂载beforeMountMounted
更新beforeUpdateupdated
销毁beforeDestroydestroyed

 下图展示了实例的生命周期:

如何理解Vue生命周期和钩子函数

2.2 初始化阶段

new Vue() – Vue实例化(组件也是一个小的Vue实例)

Init Events & Lifecycle – 初始化事件和生命周期函数

beforeCreate – 生命周期钩子函数被执行

Init injections&reactivity – Vue内部添加data和methods等

created – 生命周期钩子函数被执行, 实例创建

接下来是编译模板阶段 –开始分析

Has el option? – 是否有el选项 – 检查要挂到哪里

没有. 调用$mount()方法

有, 继续检查template选项

如何理解Vue生命周期和钩子函数

<script>export default {    data(){        return {            msg: "hello, Vue"        }    },    // 一. 初始化    // new Vue()以后, vue内部给实例对象添加了一些属性和方法, data和methods初始化"之前"    beforeCreate(){        console.log("beforeCreate -- 执行");        console.log(this.msg); // undefined    },    // data和methods初始化以后    // 场景: 网络请求, 注册全局事件    created(){        console.log("created -- 执行");        console.log(this.msg); // hello, Vue         this.timer = setInterval(() => {            console.log("哈哈哈");        }, 1000)    }}</script>

2.3 挂载阶段

template选项检查

有 - 编译template返回render渲染函数

无 – 编译el选项对应标签作为template(要渲染的模板)

虚拟DOM挂载成真实DOM之前

beforeMount – 生命周期钩子函数被执行

Create … – 把虚拟DOM和渲染的数据一并挂到真实DOM上

真实DOM挂载完毕

mounted – 生命周期钩子函数被执行

如何理解Vue生命周期和钩子函数

<template>  <div>      <p>学习生命周期 - 看控制台打印</p>      <p id="myP">{{ msg }}</p>  </div></template> <script>export default {    // ...省略其他代码        // 二. 挂载    // 真实DOM挂载之前    // 场景: 预处理data, 不会触发updated钩子函数    beforeMount(){        console.log("beforeMount -- 执行");        console.log(document.getElementById("myP")); // null         this.msg = "重新值"    },    // 真实DOM挂载以后    // 场景: 挂载后真实DOM    mounted(){        console.log("mounted -- 执行");        console.log(document.getElementById("myP")); // p    }}</script>

2.4 更新阶段

当data里数据改变, 更新DOM之前

beforeUpdate – 生命周期钩子函数被执行

Virtual DOM…… – 虚拟DOM重新渲染, 打补丁到真实DOM

updated – 生命周期钩子函数被执行

当有data数据改变 – 重复这个循环

如何理解Vue生命周期和钩子函数

<template>  <div>      <p>学习生命周期 - 看控制台打印</p>      <p id="myP">{{ msg }}</p>      <ul id="myUL">          <li v-for="(val, index) in arr" :key="index">              {{ val }}          </li>      </ul>      <button @click="arr.push(1000)">点击末尾加值</button>  </div></template> <script>export default {    data(){        return {            msg: "hello, Vue",            arr: [5, 8, 2, 1]        }    },      // 三. 更新    // 前提: data数据改变才执行    // 更新之前    beforeUpdate(){        console.log("beforeUpdate -- 执行");        console.log(document.querySelectorAll("#myUL>li")[4]); // undefined    },    // 更新之后    // 场景: 获取更新后的真实DOM    updated(){        console.log("updated -- 执行");        console.log(document.querySelectorAll("#myUL>li")[4]); // li    }}</script>

2.5 销毁阶段

当$destroy()被调用 – 比如组件DOM被移除(例v-if)

beforeDestroy – 生命周期钩子函数被执行

拆卸数据监视器、子组件和事件侦听器

实例销毁后, 最后触发一个钩子函数

destroyed – 生命周期钩子函数被执行

如何理解Vue生命周期和钩子函数

<script>export default {    // ...省略其他代码        // 四. 销毁    // 前提: v-if="false" 销毁Vue实例    // 场景: 移除全局事件, 移除当前组件, 计时器, 定时器, eventBus移除事件$off方法    beforeDestroy(){        // console.log('beforeDestroy -- 执行');        clearInterval(this.timer)    },    destroyed(){        // console.log("destroyed -- 执行");    }}</script>

最后:

面试题:

1.vue生命周期总共分为几个阶段?

(1) beforeCreate

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

(2) created

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

(3) beforeMount

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

(4) mounted

el 被新创建的 vm.$el 替换,并挂载到实例上去之后调用该钩子。如果 root 实例挂载了一个文档内元素,当 mounted 被调用时 vm.$el 也在文档内。

(5) beforeUpdate

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

(6) updated

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

(7) activated

keep-alive 组件激活时调用。该钩子在服务器端渲染期间不被调用。

(8) deactivated

keep-alive 组件停用时调用。该钩子在服务器端渲染期间不被调用。

(9) beforeDestroy

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

(10) destroyed

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

(11) errorCaptured(2.5.0+ 新增)

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

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

beforeCreate, created, beforeMount, mounted 这几个钩子函数

上述就是小编为大家分享的如何理解Vue生命周期和钩子函数了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯