Vue生命周期钩子函数全解析,2024年最新2024必看-前端高级面试题总结

  • 可以进行数据的更改,并且beforeUpdate,updated执行,因为真实dom已经渲染出来了

  • 这个钩子函数可以用来做一些实例化的相关操作

Vue.component(“my-component”, {

template: “#my-component”,

data() {

return {

msg: “1”

}

},

//mounted钩子函数是真实dom渲染之后

//数据已经挂载完毕了,真实的dom也已经渲染出来了

//可以进行数据的更改,并且beforeUpdate,updated执行,因为真实dom已经渲染出来了

//这个钩子函数可以用来做一些实例化的相关操作

mounted(){

console.log(“mounted钩子函数…”)

this.msg=2

console.log(this.msg) //2

console.log(document.getElementById(“title”))

//

hello 数据msg===>{{msg}}

},

beforeUpdate(){

//执行

console.log(“beforeUpdate钩子函数…”)

},

updated(){

//执行

console.log(“update钩子函数…”)

}

})

  • 运行

在这里插入图片描述

beforeUpdateupdate
  • beforeUpdate

  • 运行时钩子函数初始化阶段是不会主动执行的

  • 只有内存中的虚拟dom渲染为真实dom,然后再数据发生变化的时候,beforeUpdate这个钩子函数才会执行

  • beforeUpdate钩子函数里,在这里获取dom里面的数据,是更新之前的数据

  • update

  • 这个钩子函数里面dom获取的数据内容是更新后的内容

  • 生成新的虚拟dom,与上一次的虚拟dom结构进行对比,比较出来差异(diff算法),再去进行真实dom的重新渲染

  • updated钩子函数里,在这里获取dom里面的数据跟你在内存里面的data数据趋于一致,就是更新之后的数据

Vue.component(“my-component”, {

template: “#my-component”,

data() {

return {

msg: “1”

}

},

//运行时钩子函数初始化阶段是不会主动执行的

//只有内存中的虚拟dom渲染为真实dom,然后再数据发生变化的时候,beforeUpdate这个钩子函数才会执行

//beforeUpdate钩子函数里,在这里获取dom里面的数据,是更新之前的数据

beforeUpdate(){

console.log(“beforeUpdate中的this.msg”,this.msg)

console.log(“beforeUpdate钩子函数…”,document.getElementById(“title”).innerHTML)

},

//这个钩子函数里面dom获取的数据内容是更新后的内容

//生成新的虚拟dom,与上一次的虚拟dom结构进行对比,比较出来差异(diff算法),再去进行真实dom的重新渲染

//updated钩子函数里,在这里获取dom里面的数据跟你在内存里面的data数据趋于一致,就是更新之后的数据

updated(){

console.log(“updatad中的this.msg”,this.msg)

console.log(“updated钩子函数…”,document.getElementById(“title”).innerHTML)

}

})

  • 运行,通过输入框将数据从1变为12

在这里插入图片描述

beforeDestroydestroyed
beforeDestroy
  • 当组件销毁的时候,就会触发, vm.$destory()

  • beforeDestroy钩子函数表示销毁之前,我们可以进行一些善后操作

  • 例如:清除一些事件绑定,清除定时器的相关操作

destroyed
  • 组件一旦被销毁了,组件的dom结构还是存在的

  • 只是组件的双向数据绑定,事件监听,watch相关的已经被移除掉了

brforeDestroy的应用
  • 要对这两个钩子函数进行了解,得先进行销毁操作,因此,我们可以添加一个按钮,当点击之后,销毁实例

hello 数据msg===>{{msg}}

<button @click=“destroy”>销毁实例

  • 销毁之前,数据与输入框双向绑定

在这里插入图片描述

  • 点击按钮,销毁之后,

在这里插入图片描述

清除定时器的相关操作

hello 数据msg===>{{msg}}

<button @click=“destroy”>销毁实例

  • 如果不清除在created中的定时器,那么在销毁函数之后,定时器也一直在开启
    在这里插入图片描述
  • 在beforeDestroy中添加清除定时器事件之后,定时器不会一直在开启
    在这里插入图片描述

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

自学几个月前端,为什么感觉什么都没学到??


这种现象在很多的初学者和自学前端的同学中是比较的常见的。

因为自学走的弯路是比较的多的,会踩很多的坑,学习的过程中是比较的迷茫的。

最重要的是,在学习的过程中,不知道每个部分该学哪些知识点,学到什么程度才算好,学了能做什么。

很多自学的朋友往往都是自己去找资料学习的,资料上有的或许就学到了,资料上没有的或许就没有学到。

这就会给人一个错误的信息就是,我把资料上的学完了,估计也-就差不多的了。

但是真的是这样的吗?非也,因为很多人找的资料就是很基础的。学完了也就是掌握一点基础的东西。分享给你一份前端分析路线,你可以参考。

还有很多的同学在学习的过程中一味的追求学的速度,很快速的刷视频,写了后面忘了前面,最后什么都没有学到,什么都知道,但是什么都不懂,要具体说,也说不出个所以然。

所以学习编程一定要注重实践操作,练习敲代码的时间一定要多余看视频的时间。

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
img

学到。

这就会给人一个错误的信息就是,我把资料上的学完了,估计也-就差不多的了。

但是真的是这样的吗?非也,因为很多人找的资料就是很基础的。学完了也就是掌握一点基础的东西。分享给你一份前端分析路线,你可以参考。

还有很多的同学在学习的过程中一味的追求学的速度,很快速的刷视频,写了后面忘了前面,最后什么都没有学到,什么都知道,但是什么都不懂,要具体说,也说不出个所以然。

所以学习编程一定要注重实践操作,练习敲代码的时间一定要多余看视频的时间。

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-26tIM14r-1712778781347)]

  • 8
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值