生命周期
===
[TOC]
*****
uni-app 完整支持 Vue 實例的生命周期,同時還支持應用生命周期及頁面生命周期。
# Vue實例生命周期
支持vue實例的如下生命周期函數,
* beforeCreate
* created
* beforeMount
* mounted
* beforeUpdate
* updated
* activated
* deactivated
* beforeDestroy
* destroyed
> 不要在選項屬性或回調上使用箭頭函數,比如 `created: () => console.log(this.a)` ,因為箭頭函數是和父級上下文綁定在一起的,this 不會是如你做預期的 Vue 實例,且 this.a 也會是未定義的。
# 應用生命周期
uni-app 支持如下應用生命周期函數:
| 函數名 | 說明 |
|----------|------------------------------------------|
| onLaunch | 當uni-app?初始化完成時觸發(全局只觸發一次) |
| onShow | 當?uni-app?啟動,或從后臺進入前臺顯示 |
| onHide | 當?uni-app?從前臺進入后臺 |
> 應用生命周期僅可在App.vue中監聽,在其它頁面監聽無效。
App.vue文件:
```
<script>
export default {
onLaunch: function () {
console.log('App Launch')
},
onShow: function () {
console.log('App Show')
},
onHide: function () {
console.log('App Hide')
}
}
</script>
```
onLaunch事件可以做一些初始化的操作,如加載緩存到本地的購物車數據,檢測版本升級等。
```
export default {
onLaunch: function () {
this.$store.dispatch('loadStorage'); //加載本地緩存的數據
console.log('App Launch')
},
```
這里加載本地緩存數據使用了VUEX實現。
# 頁面生命周期
uni-app 支持如下頁面生命周期函數:
| 函數名 | 說明 | 平臺支持 |
|--------------------------|----------------------------------------------------------------------|------------|
| onLoad | 監聽頁面加載,其參數為上個頁面傳遞的數據,參數類型為Object(用于頁面傳參) | |
| onShow | 監聽頁面顯示 | |
| onReady | 監聽頁面初次渲染完成 | |
| onHide | 監聽頁面隱藏 | |
| onUnload | 監聽頁面卸載 | |
| onPullDownRefresh | 監聽用戶下拉動作,一般用于下拉刷新 | |
| onReachBottom | 頁面上拉觸底事件的處理函數 | |
| onShareAppMessage | 用戶點擊右上角分享 | 微信小程序 |
| onNavigationBarButtonTap | 監聽原生標題欄按鈕點擊事件,參數為Object | 5+ App |
| onPageScroll | 監聽頁面滾動,參數為Object | |
| onTabItemTap | 當前是?tab?頁時,點擊?tab?時觸發。 | |
onPageScroll 參數說明:
| 屬性 | 類型 | 說明 |
|-----------|--------|----------------------------------|
| scrollTop | Number | 頁面在垂直方向已滾動的距離(單位px) |
onNavigationBarButtonTap 參數說明:
| 屬性 | 類型 | 說明 |
|-------|--------|------------------------|
| index | Number | 原生標題欄按鈕數組的下標 |
注意
* 先觸發uni-app onReady ,后觸發 vue mounted
* 建議使用uni-app onLoad 代替 vue created
# 生命周期的例子
比如下面的實例,每秒更新一個隨機數,這個例子演示了uni-app的生命周期中的onLoad和onUnload事件。
首先在頁面加載完成的事件onLoad中創建計時器,
```
onLoad: function(e) {
self = this; //self指向vm的實例
this.timer = setInterval(function() {
self.random = Math.random(); //修改對象
}, 1000);
},
```
> onLoad事件一般可以帶一個參數,用來給頁面傳遞參數。
然后在onUnload事件中銷毀計時器。
```
onUnload: function() {
if (this.timer) {
clearInterval(this.timer); //銷毀定時器
}
}
```
文件pages/lab/gramma/random.vue的內容如下:
```
<template>
<view>
<view>
<text>{{ random }}</text>
</view>
</view>
</template>
<script>
var self;
export default {
data: {
random: 0,
timer: null,
},
onLoad: function(e) {
self = this; //self指向vm的實例
this.timer = setInterval(function() {
self.random = Math.random(); //修改對象
}, 1000);
},
onUnload: function() {
if (this.timer) {
clearInterval(this.timer); //銷毀定時器
}
}
}
</script>
<style>
</style>
```
由于Javascript對象的this指針的作用域問題,一般定義個一全局變量self,
```
<script>
var self = null;
```
在onLoad事件中首先初始化為對象自身,方便在生命周期內的其他地方使用。
```
onLoad: function () {
self = this;
this.timer = setInterval(function () {
self.random = Math.random(); //修改對象
}, 1000);
},
```
- 內容介紹
- EcmaScript基礎
- 快速入門
- 常量與變量
- 字符串
- 函數的基本概念
- 條件判斷
- 數組
- 循環
- while循環
- for循環
- 函數基礎
- 對象
- 對象的方法
- 函數
- 變量作用域
- 箭頭函數
- 閉包
- 高階函數
- map/reduce
- filter
- sort
- Promise
- 基本對象
- Arguments 對象
- 剩余參數
- Map和Set
- Json基礎
- RegExp
- Date
- async
- callback
- promise基礎
- promise-api
- promise鏈
- async-await
- 項目實踐
- 標簽系統
- 遠程API請求
- 面向對象編程
- 創建對象
- 原型繼承
- 項目實踐
- Classes
- 構造函數
- extends
- static
- 項目實踐
- 模塊
- import
- export
- 項目實踐
- 第三方擴展庫
- immutable
- Vue快速入門
- 理解MVVM
- Vue中的MVVM模型
- Webpack+Vue快速入門
- 模板語法
- 計算屬性和偵聽器
- Class 與 Style 綁定
- 條件渲染
- 列表渲染
- 事件處理
- 表單輸入綁定
- 組件基礎
- 組件注冊
- Prop
- 自定義事件
- 插槽
- 混入
- 過濾器
- 項目實踐
- 標簽編輯
- 移動客戶端開發
- uni-app基礎
- 快速入門程序
- 單頁程序
- 底部Tab導航
- Vue語法基礎
- 模版語法
- 計算屬性與偵聽器
- Class與Style綁定
- 樣式與布局
- Box模型
- Flex布局
- 內置指令
- 基本指令
- v-model與表單
- 條件渲染指令
- 列表渲染指令v-for
- 事件與自定義屬性
- 生命周期
- 項目實踐
- 學生實驗
- 貝店商品列表
- 加載更多數據
- 詳情頁面
- 自定義組件
- 內置組件
- 表單組件
- 技術專題
- 狀態管理vuex
- Flyio
- Mockjs
- SCSS
- 條件編譯
- 常用功能實現
- 上拉加載更多數據
- 數據加載綜合案例
- Teaset UI組件庫
- Teaset設計
- Teaset使用基礎
- ts-tag
- ts-badge
- ts-button
- ta-banner
- ts-list
- ts-icon
- ts-load-more
- ts-segmented-control
- 代碼模版
- 項目實踐
- 標簽組件
- 失物招領客戶端原型
- 發布頁面
- 檢索頁面
- 詳情頁面
- 服務端開發技術
- 服務端開發環境配置
- Koajs快速入門
- 快速入門
- 常用Koa中間件介紹
- 文件上傳
- RestfulApi
- 一個復雜的RESTful例子
- 使用Mockjs生成模擬數據
- Thinkjs快速入門
- MVC模式
- Thinkjs介紹
- 快速入門
- RESTful服務
- RBAC案例
- 關聯模型
- 應用開發框架
- 服務端開發
- PC端管理界面開發
- 移動端開發
- 項目實踐
- 失物招領項目
- 移動客戶端UI設計
- 服務端設計
- 數據庫設計
- Event(事件)
- 客戶端設計
- 事件列表頁面
- 發布頁面
- 事件詳情頁面
- API設計
- image
- event
- 微信公眾號開發
- ui設計規范