Vue——生命周期

实体创建周期中自带的方法

beforeCreate——在实例初始化之后,数据观测 (data observer) 和 event/watcher 事件配置之前被调用。

created——在实例创建完成后被立即调用,实例已完成以下的配置:数据观测 (data observer),属性和方法的运算,watch/event 事件回调,挂载阶段还没开始,$el 属性目前不可见

beforeMount——在挂载开始之前被调用:相关的渲染函数首次被调用

mounted——el 被新创建的 vm.$el 替换, 挂载成功

响应前后的方法

beforeUpdate——数据更新时调用

updated——数据更新完成时被调用

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<script src="vue.js" type="text/javascript" charset="utf-8"></script>
</head>
<body>
<div id="app">
	{{msg}}
</div>
<script type="text/javascript">
var vm = new Vue({
	el : "#app",
	data : {
		msg : "hi vue",
	},
	//在实例初始化之后,数据观测 (data observer) 和 event/watcher 事件配置之前被调用。
	beforeCreate:function(){
		console.log('beforeCreate');
	},
	/* 在实例创建完成后被立即调用。
	在这一步,实例已完成以下的配置:数据观测 (data observer),属性和方法的运算,watch/event 事件回调。
	然而,挂载阶段还没开始,$el 属性目前不可见。 */
	created	:function(){
		console.log('created');
	},
	//在挂载开始之前被调用:相关的渲染函数首次被调用
	beforeMount : function(){
		console.log('beforeMount');

	},
	//el 被新创建的 vm.$el 替换, 挂载成功	
	mounted : function(){
		console.log('mounted');
	
	},
	//数据更新时调用
	beforeUpdate : function(){
		console.log('beforeUpdate');
			
	},
	//组件 DOM 已经更新, 组件更新完毕 
	updated : function(){
		console.log('updated');
			
	}
});
//三秒钟后执行
setTimeout(function(){
	vm.msg = "change ......";
}, 3000);
</script>
</body>
</html>

执行结果:

生命周期

生命流程图