生命周期示例图:
每个 Vue 实例在被创建时都要经过一系列的初始化过程——例如,需要设置数据监听、编译模板、将实例挂载到 DOM 并在数据变化时更新 DOM 等。同时在这个过程中也会运行一些叫做生命周期钩子的函数,这给了用户在不同阶段添加自己的代码的机会。
每个生命周期都会有对应的生命周期的函数,或者叫做勾子函数;
实例:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div id="app">
<p>{{name}}</p>
<button @click="update">update</button>
<button @click="destroy">destroy</button>
</div>
<script type="text/javascript" src="js/vue2.6.js"></script>
<script type="text/javascript">
new Vue({
el:'#app',
data:{
name: ''
},
methods:{
update(){
this.name='修改后的数据'
},
destroy(){
this.$destroy();
}
},
mounted(){ // 只执行一次
console.log('mounted() 页面初始化完成')
this.name="初始化数据"
},
beforeUpdate(){ // 执行多次
console.log('beforeUpdate() 数据属性更新之前')
},
updated(){ // 执行多次
console.log('updated() 数据属性更新之后')
},
beforeDestroy(){ // 只执行一次
console.log('beforeDestroy() vm 销毁之前')
},
destroyed(){ // 只执行一次
console.log('beforeDestroy() vm 销毁之后')
}
});
</script>
</body>
</html>
生命周期主要有三个阶段:
一,初始化显示;(重要勾子 mounted 网页加载完毕触发)
二,更新显示;(重要勾子beforeUpdate 数据属性更新前)
三,死亡;(重要勾子beforeDestroy vm死亡前)