-
可以进行数据的更改,并且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钩子函数…”)
}
})
- 运行
beforeUpdate
和 update
-
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
beforeDestroy
和 destroyed
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前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
自学几个月前端,为什么感觉什么都没学到??
这种现象在很多的初学者和自学前端的同学中是比较的常见的。
因为自学走的弯路是比较的多的,会踩很多的坑,学习的过程中是比较的迷茫的。
最重要的是,在学习的过程中,不知道每个部分该学哪些知识点,学到什么程度才算好,学了能做什么。
很多自学的朋友往往都是自己去找资料学习的,资料上有的或许就学到了,资料上没有的或许就没有学到。
这就会给人一个错误的信息就是,我把资料上的学完了,估计也-就差不多的了。
但是真的是这样的吗?非也,因为很多人找的资料就是很基础的。学完了也就是掌握一点基础的东西。分享给你一份前端分析路线,你可以参考。
还有很多的同学在学习的过程中一味的追求学的速度,很快速的刷视频,写了后面忘了前面,最后什么都没有学到,什么都知道,但是什么都不懂,要具体说,也说不出个所以然。
所以学习编程一定要注重实践操作,练习敲代码的时间一定要多余看视频的时间。
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
学到。
这就会给人一个错误的信息就是,我把资料上的学完了,估计也-就差不多的了。
但是真的是这样的吗?非也,因为很多人找的资料就是很基础的。学完了也就是掌握一点基础的东西。分享给你一份前端分析路线,你可以参考。
还有很多的同学在学习的过程中一味的追求学的速度,很快速的刷视频,写了后面忘了前面,最后什么都没有学到,什么都知道,但是什么都不懂,要具体说,也说不出个所以然。
所以学习编程一定要注重实践操作,练习敲代码的时间一定要多余看视频的时间。
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-26tIM14r-1712778781347)]