1.什么是组件生命周期
一个组件从 创建 到 销毁 的整个过程就是生命周期
激活失活
不常用的钩子函数
<font color=99999>**/* 另外三个生命周期函数不常用*/**</font>
keep-alive 主要用于保留组件状态或避免重新渲染。
activated只有在keep-alive 组件激活时调用。
deactivated只有在keep-alive 组件停用时调用。
errorCapured 当捕获一个来自子孙组件的错误时被调用。此钩子会收到三个参数:错误对象、发生错误的组件实例以及一个包含错误来源信息的字符串。此钩子可以返回 `false` 以阻止该错误继续向上传播。
2. 生命周期函数(钩子函数) 四个阶段 (一个阶段两个钩子函数) 八个钩子
vue 框架内置函数,随着组件的生命周期,自动 按次序 执行
**作用:**特定的时间点,执行某些特定的操作
场景: 组件创建完毕后,可以在created 生命周期函数中发起Ajax 请求,从而初始化 data 数据
3.生命周期函数(钩子函数) 四个阶段:
● 初始化 => 创建组件 => beforeCreate created
● 挂载 => 渲染显示组件 => beforeMount mouted
● 更新 => 修改了变量 => 触发视图刷新 => beforeUpdate updated
● 销毁 => 切换页面 => 会把组件对象从内存删除 => beforeDestory destoryed
官网参考
4.生命周期函数执行过程 ## 钩子函数 必会 初始代码参考
4个阶段 初始化 挂载 更新 销毁
created () 90% 挂载 发ajax 可以访问data中定义的数据
mounted () 5% 挂载 可以访问dom元素
destroyed () 5% 销毁 清空定时器 取消事件绑定
Vue 的父组件和子组件生命周期钩子函数执行顺序
Vue 的父组件和子组件生命周期钩子函数执行顺序可以归类为以下 4 部分:
加载渲染过程:
父 beforeCreate -> 父 created -> 父 beforeMount -> 子 beforeCreate -> 子 created -> 子 beforeMount -> 子 mounted -> 父 mounted
子组件更新过程:
父 beforeUpdate -> 子 beforeUpdate -> 子 updated -> 父 updated
父组件更新过程:
父 beforeUpdate -> 父 updated
销毁过程:
父 beforeDestroy -> 子 beforeDestroy -> 子 destroyed -> 父 destroyed
总结:
子的生命周期都会被先结束,父的才结束。先由父到子,再从子到父。
生命周期遵从“从外到内,再从内到外,mixins先于组件”的原则。
总的来说,从创建到挂载,是从外到内,再从内到外,且mixins的钩子函数总是在当前组件之前执行
子组件
<template>
<div>
<ul id="myUl">
<li v-for="(item, ind) in arr" :key="ind">{
{
item }}</li>
</ul>
<button
@click="arr.push(Math.random() * 10)"
>
增加一个元素
</button>
</div>
</template>
<script>
export default {
data () {
return {
msg: "我是变量",
arr: [1, 2, 3, 4]
}
},
beforeCreate () {
// 1. 创建前
console.log("beforeCreate --- 实例初始化前")
console.log(this.msg) // undefined
},
created () {
// 2. 创建后=> 发送ajax请求
console.log("created --- 实例初始化后")
console.log(this.msg) // "我是变量"
// 给对象添加属性
this.timer = setInterval(()=>{
console.log(Date.now())
}, 1000)
this.fn = ()=>{
console.log(Date.now())}
document.addEventListener('mousemove', this.fn)
},
beforeMount () {
// 3. 挂载前
console.log("beforeMount --- vue的虚拟DOM, 挂载到真实的网页之前")
console.log(document.getElementById("myUl")) // null
// console.log(document.getElementById("myUl").children[1].innerHTML) // 报错