微信小程序 註冊程序 App()函數

App

App()


App()函數用來註冊一個小程序。接受一個object參數,其指定小程序的生命週期函數等。

object參數說明:

屬性類型描述觸發時機
onLaunchFunction生命週期函數--監聽小程序初始化當小程序初始化完成時,會觸發 onLaunch(全局只觸發一次)
onShowFunction生命週期函數--監聽小程序顯示當小程序啓動,或從後臺進入前臺顯示,會觸發 onShow
onHideFunction生命週期函數--監聽小程序隱藏當小程序從前臺進入後臺,會觸發 onHide
onErrorFunction錯誤監聽函數當小程序發生腳本錯誤,或者 api 調用失敗時,會觸發 onError 並帶上錯誤信息
onPageNotFound
Function
頁面不存在監聽函數
當小程序出現要打開的頁面不存在的情況,會帶上頁面信息回調該函數,詳見下文
其他Any
開發者可以添加任意的函數或數據到 Object 參數中,用 this 可以訪問

前臺、後臺定義:當用戶點擊左上角關閉,或者按了設備 Home 鍵離開微信,小程序並沒有直接銷燬,而是進入了後臺;當再次進入微信或再次打開小程序,又會從後臺進入前臺。需要注意的是:只有當小程序進入後臺一定時間,或者系統資源佔用過高,纔會被真正的銷燬。

關閉小程序(基礎庫版本1.1.0開始支持):當用戶從掃一掃、轉發等入口(場景值爲1007, 1008, 1011, 1025)進入小程序,且沒有置頂小程序的情況下退出,小程序會被銷燬。小程序運行機制在基礎庫版本 1.4.0 有所改變:上一條關閉邏輯在新版本已不適用, 詳情

示例代碼:

App({
  onLaunch: function(options) {
    // Do something initial when launch.
  },
  onShow: function(options) {
      // Do something when show.
  },
  onHide: function() {
      // Do something when hide.
  },
  onError: function(msg) {
    console.log(msg)
  },
  globalData: 'I am global data'
})

onLaunch, onShow 參數

字段類型說明
pathString打開小程序的路徑
queryObject打開小程序的query
sceneNumber打開小程序的場景值
shareTicketStringshareTicket,詳見 獲取更多轉發信息
referrerInfoObject當場景爲由另一個小程序打開時,返回此字段
referrerInfo.appIdString來源小程序的 appId
referrerInfo.extraDataObject來源小程序傳過來的數據

場景值 詳見。

以下場景支持返回 referrerInfo.appId:

場景值場景appId 信息含義
1020公衆號 profile 頁相關小程序列表返回來源公衆號 appId
1035公衆號自定義菜單返回來源公衆號 appId
1036App 分享消息卡片返回來源應用 appId
1037小程序打開小程序返回來源小程序 appId
1038從另一個小程序返回返回來源小程序 appId
1043公衆號模板消息返回來源公衆號 appId

onPageNotFound

基礎庫 1.9.90 開始支持,低版本需做兼容處理

當要打開的頁面並不存在時,會回調這個監聽器,並帶上以下信息:

字段類型說明
pathString不存在頁面的路徑
queryObject打開不存在頁面的 query
isEntryPageBoolean是否本次啓動的首個頁面(例如從分享等入口進來,首個頁面是開發者配置的分享頁面)

開發者可以在 onPageNotFound 回調中進行重定向處理,但必須在回調中同步處理,異步處理(例如 setTimeout 異步執行)無效。

示例代碼:

App({
  onPageNotFound(res) {
    wx.redirectTo({
      url: 'pages/...'
    })
  }
})

注意:

  1. 微信開發者工具暫不支持 onPageNotFound 調試,請使用真機調試

  2. 如果開發者沒有添加 onPageNotFound 監聽,當跳轉頁面不存在時,將推入微信客戶端原生的頁面不存在提示頁面

  3. 如果 onPageNotFound 回調中又重定向到另一個不存在的頁面,將推入微信客戶端原生的頁面不存在提示頁面,並且不在回調 onPageNotFound

getApp()


我們提供了全局的getApp()函數,可以獲取到小程序實例。

// other.js
var appInstance = getApp()
console.log(appInstance.globalData) // I am global data

注意:App()必須在app.js中註冊,且不能註冊多個。

不要在定義於App()內的函數中調用getApp(),使用this就可以拿到app實例。

不要在onLaunch的時候調用getCurrentPage(),此時page還沒有生成。

通過getApp()獲取實例之後,不要私自調用生命週期函數。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章