不论是app还是小程序,生命周期是非常重要的知识点。
uni-app 支持如下生命周期函数:
页面的生命周期
onLoad 监听页面加载,其参数为上个页面传递的数据,参数类型为object(用于页面传参),参考示例onShow 监听页面显示onReady 监听页面初次渲染完成onHide 监听页面隐藏onUnload 监听页面卸载onPullDownRefresh 监听用户下拉动作onReachBottom 页面上拉触底事件的处理函数onShareAppMessage 用户点击右上角分享 微信小程序onPageScroll 监听页面滚动onTabItemTap 当前是 tab 页时,点击 tab 时触发
1 <script> 2 export default { 3 data() { 4 return { 5 title: 'Hello' 6 } 7 }, 8 onLoad() { 9 console.log('页面加载') 10 }, 11 onShow() { 12 console.log('页面显示') 13 }, 14 onReady(){ 15 console.log('页面初次显示') 16 }, 17 onHide() { 18 console.log('页面隐藏') 19 }, 20 onUnload() { 21 console.log('页面卸载') 22 }, 23 onBackPress(){ 24 console.log('页面返回...') 25 }, 26 onShareAppMessage() { 27 console.log('分享!') 28 }, 29 onReachBottom() { 30 console.log('下拉加载...') 31 }, 32 onPageScroll(){ 33 console.log('页面滚动...') 34 }, 35 onPullDownRefresh() { 36 console.log('上拉刷新...') 37 uni.stopPullDownRefresh(); 38 }, 39 40 // #ifdef APP-PLUS 41 onNavigationBarButtonTap(){ 42 43 }, 44 // #endif 45 46 methods: { 47 tap(){ 48 console.log('tap点击!'); 49 } 50 } 51 } 52 </script>
组件的生命周期
beforeCreate 组件初始化,但数据原生观测、自定义观测(event\watcher)没生成之前。 未完全创建阶段created 组件创建后,但还未挂载 完全创建阶段beforeMount 组件渲染后,挂载前。 渲染后待挂载mounted 组件挂载到页面 可用 vm.$el 访问 挂载OKbeforeUpdate 虚拟 DOM 重新渲染和打补丁之前 再次渲染前updated 组件 DOM 已经更新 再次渲染后activated keep-alive 组件激活时调用。 当前组件被激活:显示deactivated keep-alive 组件停用时调用。 当前组件隐藏beforeDestroy 实例销毁之前调用。实例仍然完全可用。 销毁前destroy Vue 实例销毁后调用
注:挂载阶段,先渲染组件,然后挂载组件。
<script>
export default {
data() {
return {
title: 'Hello'
}
},
props:{},
beforeCreate() {
console.log('组件初始化,未完全创建阶段')
},
created() {
console.log('组件创建后,但还未挂载')
},
beforeMount(){
console.log('渲染后待挂载')
},
mounted() {
console.log('组件挂载到页面OK,可用 vm.$el 访问')
},
beforeUpdate() {
console.log('再次渲染前')
},
updated(){
console.log('再次渲染后')
},
activated() {
console.log('当前组件被激活:显示')
},
deactivated() {
console.log('当前组件隐藏')
},
beforeDestroy(){
console.log('销毁前')
},
destroy() {
console.log('销毁后')
},
methods: {
tap(){
console.log('tap点击!');
}
}
}
</script>
