Vue的生命周期:
一个Vue实例从创建到销毁的整个过程
创建阶段的最后发送初始化渲染的请求(越早越好) 挂载阶段的最后可以开始操作dom()至少dom得渲染出来
Vue的生命周期函数(钩子函数)
Vue生命周期过程中,会自动运行一些函数,被称为生命周期钩子 ->让开发者可以在特定阶段运行自己的代码。
钩子函数的实例
<div id="app">
<h3>{{ title }}</h3>
<div>
<button @click="count--">-</button>
<span>{{ count }}</span>
<button @click="count++">+</button>
</div>
</div>
const app = new Vue({
el: '#app',
data: {
count: 100,
title: '计数器'
},
// 1.创建阶段(准备数据)
beforeCreate(){
console.log('',this.count); // undefined
},
created(){
console.log('',this.count); // 100
// this.数据名=请求回来的数据
// 可以开始发送初始化渲染的请求了
},
//2.挂载阶段(渲染模版)
beforeMount(){
console.log('',document.querySelector('h3').innerHTML);
}, // beforeMount 模板渲染之前 {{ title }}
mounted(){
console.log('',document.querySelector('h3').innerHTML); // mounted 模板渲染之后 计数器
//可以开始操作dom了
},
//3.更新阶段(修改数据 ->更新视图)
beforeUpdate(){
console.log('数据修改了,视图没更新',document.querySelector('span').innerHTML);
}, // beforeUpdate 数据修改了,视图还没更新, 100
Update(){
console.log('数据修改了,视图也更新了',document.querySelector('span').innerHTML);
}, // updated 数据修改了,视图已经更新, 101
//4.卸载阶段
beforeDestroy(){
console.log('beforeDestroy,卸载前');
console.log('清除掉一些Vue以外的资源占用,定时器,延时器...');
},
destroy(){
console.log('destroyed,卸载后');
}
})