什么是 vue 生命周期
Vue 实例从创建到销毁的过程,就是生命周期。也就是从开始创建、初始化数据、编译模板、挂载Dom→渲染、更新→渲染、卸载等一系列过程,我们称这是 Vue 的生命周期。
生命周期函数
Vue 的生命周期总共分为8个阶段:创建前/后,载入前/后,更新前/后,销毁前/后。
1、beforeCreate(创建前)
表示实例完全被创建出来之前,vue 实例的挂载元素$el和数据对象 data 都为 undefined,还未初始化。
特点: 有this,没有data与methods
2、created(创建后)
数据对象 data 已存在,可以调用 methods 中的方法,操作 data 中的数据,但 dom 未生成,$el 未存在 。
特点: 有data,没有$el,dom节点
用处: ajax请求,定时器,事件监听
3、beforeMount(挂载前)
vue 实例的 $el 和 data 都已初始化,挂载之前为虚拟的 dom节点,模板已经在内存中编辑完成了,但是尚未把模板渲染到页面中。data.message 未替换。
特点: 有$el,数据没有渲染
4、mounted(挂载后)
vue 实例挂载完成,data.message 成功渲染。内存中的模板,已经真实的挂载到了页面中,用户已经可以看到渲染好的页面了。实例创建期间的最后一个生命周期函数,当执行完 mounted 就表示,实例已经被完全创建好了,DOM 渲染在 mounted 中就已经完成了。
特点: 有dom节点,数据也渲染
用处: 操作节点,ajax请求
5、beforeUpdate(更新前)
当 data 变化时,会触发beforeUpdate方法 。data 数据尚未和最新的数据保持同步。
特点:会执行多次 数据更新,dom节点没有更新
6、updated(更新后)
当 data 变化时,会触发 updated 方法。页面和 data 数据已经保持同步了。
特点:会执行多次 数据更新,dom节点也更新
7、beforeDestory(销毁前)
组件销毁之前调用 ,在这一步,实例仍然完全可用。
特点: 数据可以更新,视图已经不更新
用处: 移除事件监听,停止定时器
8、destoryed(销毁后)
组件销毁之后调用,对 data 的改变不会再触发周期函数,vue 实例已解除事件监听和 dom绑定,但 dom 结构依然存在。
特点: 没有this,切换视图与vue实例的联系
组件传参
vue组件之间的参数传递:父传子。
先在子组件中通过props:[参数]设参,然后在父组件中通过<组件标签 :参数名=“要赋予的值”></组件标签>传参,最后在子组件中接参。
//父组件代码 渲染子组件
<Son :sonName="uname" />
// 子组件代码,接受父参数
export default {
props: {
sonName: String
}
}
props是表示组件的参数部分,那么props有两种写法:
props:[“参数列表”]
比如:props:[‘prop01’,‘pro02’,‘pro03’,…]
props:{参数名1:{type:参数类型,required:是否是必须的参数true或者false,default:默认值},参数名2:{},参数名3:{},…}
比如:
props: {
"MyTitle":{
type: String,
required:true,
default:"XXX"
}
}
vue组件之间的参数传递:子传父。
简单来说和父传子其实差不多,但在这个过程中是父组件传可以改变父参数的方法给子组件,然后子组件通过这个方法的形参传递参数改变。
在子组件中定义一个带有语句this.$emit('键名', "值");方法 通过执行这个方法会将参数从底向上传
父组件通过@键="要改变的参数值=$event"接收参数。
父组件核心代码:
<template>
<div id="app">
<!-- <MyHeader></MyHeader> -->
<MyContent :MyTitle='msg' @newMsg="msg=$event"></MyContent>
<!-- <MyBotton></MyBotton> -->
</div>
</template>
子组件核心代码:
methods: {
fire:function(){
this.$emit('newMsg', "传来的参数");
}
}
// 通过单击btn的单击事件触发
<button type="button" @click="fire()">改变title内容</button>