搜尋
首頁微信小程式小程式開發微信小程式 Page()函數的介紹

微信小程式 Page()函數的介紹

Jun 22, 2018 pm 04:16 PM
微信小程式

這篇文章主要介紹了微信小程式Page()函數詳解的相關資料,在開發過程中肯定會遇到Page()函數,希望能幫助到大家,需要的朋友可以參考下

微信小程式-Page():

         在發展微信小程式的時候遇到函數,或是無法理解的地方,最好上官網查詢,相應的知識,這裡小編幫大家整理了下page()函數的用法。

Page() 函數用來註冊一個頁面。接受一個 object 參數,其指定頁面的初始資料、生命週期函數、事件處理函數等。

object 參數說明:

##類型dataonLoad#onReadyonShowonHide週期函數--監聽頁面卸載頁相關事件處理函數--監聽使用者下拉動作開發者可以加入任意的函數或資料到object 參數中,用 this 可以存取
#屬性 ##說明
Object #頁面的初始資料
Function 生命週期函數--監聽頁面載入
Function 生命週期函數--監聽頁面初次渲染完成
Function 生命週期函數--監聽頁面顯示
Function 生命週期函數--監聽頁面隱藏
onPullDownRefreash Function
其他 Any

範例程式碼:

//index.js 
Page({ 
 data: { 
  text: "This is page data." 
 }, 
 onLoad: function(options) { 
  // Do some initialize when page load. 
 }, 
 onReady: function() { 
  // Do something when page ready. 
 }, 
 onShow: function() { 
  // Do something when page show. 
 }, 
 onHide: function() { 
  // Do something when page hide. 
 }, 
 onUnload: function() { 
  // Do something when page close. 
 }, 
 onPullDownRefresh: function() { 
  // Do something when pull down 
 }, 
 // Event handler. 
 viewTap: function() { 
  this.setData({ 
   text: 'Set some data for updating view.' 
  }) 
 } 
})

#初始化資料

初始化資料將作為頁面的第一次渲染。 data 將會以 JSON 的形式由邏輯層傳至渲染層,所以其資料必須是可以轉成 JSON 的格式:字串,數字,布林值,對象,陣列。
渲染層可以透過 WXML 對資料進行綁定。

範例程式碼:

<view>{{text}}</view> 
<view>{{array[0].msg}}</view>

#
Page({ 
 data: { 
  text: &#39;init data&#39;, 
  array: [{msg: &#39;1&#39;}, {msg: &#39;2&#39;}] 
 } 
})

生命週期函數

onLoad: 頁面載入

#一個頁面只會呼叫一次。

參數可以取得wx.navigateTo和wx.redirectTo及中的 query。

onShow: 頁面顯示

每次開啟頁面都會呼叫一次。

onReady: 頁面初次渲染完成

一個頁面只會呼叫一次,代表頁面已經準備妥當,可以和視圖層進行互動。

對介面的設定如wx.setNavigationBarTitle請在onReady之後設定。詳見生命週期

onHide: 頁面隱藏

當navigateTo或底部tab切換時呼叫。

onUnload: 頁面卸載

當redirectTo或navigateBack的時候呼叫。

頁面相關事件處理函數

onPullDownRefresh: 下拉刷新

監聽使用者下拉刷新事件。

需要在config的window選項中開啟enablePullDownRefresh。

當處理完資料刷新後,wx.stopPullDownRefresh可以停止目前頁面的下拉刷新。

事件處理函數

除了初始化資料和生命週期函數,Page 中還可以定義一些特殊的函數:事件處理函數。在渲染層可以在元件中加入事件綁定,當達到觸發事件時,就會執行 Page 中定義的事件處理函數。

範例程式碼:

click me  

#
Page({ 
 viewTap: function() { 
  console.log(&#39;view tap&#39;) 
 } 
})

Page.prototype.setData()

#setData 函數用於將資料從邏輯層傳送到視圖層,同時改變對應的this.data的值。

注意:

直接修改 this.data 無效,無法改變頁面的狀態,也會造成資料不一致。
單次設定的資料不能超過1024kB,請盡量避免一次設定過多的資料。

setData() 參數格式

接受一個對象,以key,value 的形式表示將this.data 中的key 對應的值改變成value。
其中 key 可以非常靈活,以資料路徑的形式給出,如 array[2].message,a.b.c.d,並且不需要在 this.data 中預先定義。

範例程式碼:

<view>{{text}}</view> 
<button bindtap="changeText"> Change normal data </button> 
<view>{{array[0].text}}</view> 
<button bindtap="changeItemInArray"> Change Array data </button> 
<view>{{obj.text}}</view> 
<button bindtap="changeItemInObject"> Change Object data </button> 
<view>{{newField.text}}</view> 
<button bindtap="addNewField"> Add new data </button>

#
//index.js 
Page({ 
 data: { 
  text: &#39;init data&#39;, 
  array: [{text: &#39;init data&#39;}], 
  object: { 
   text: &#39;init data&#39; 
  } 
 }, 
 changeText: function() { 
  // this.data.text = &#39;changed data&#39; // bad, it can not work 
  this.setData({ 
   text: &#39;changed data&#39; 
  }) 
 }, 
 changeItemInArray: function() { 
  // you can use this way to modify a danamic data path 
  this.setData({ 
   &#39;array[0].text&#39;:&#39;changed data&#39; 
  }) 
 }, 
 changeItemInObject: function(){ 
  this.setData({ 
   &#39;object.text&#39;: &#39;changed data&#39; 
  }); 
 }, 
 addNewField: function() { 
  this.setData({ 
   &#39;newField.text&#39;: &#39;new data&#39; 
  }) 
 } 
})

以下內容你不需要立刻完全弄明白,不過以後它會有幫助。

生命週期

下圖說明了 Page 實例的生命週期。

頁面的路由

#在小程式中所有頁面的路由全部由框架管理,對於路由的觸發方式與頁面生命週期函數如下:
路由方式

  觸發時機 路由後頁面 路由前頁


# 觸發時機
路由後頁面 路由前頁面
初始化 小程式開啟的第一個頁面 onLoad,onShow  
開啟新頁面 呼叫API wx.navigateTo 或使用元件 onLoad,onShow onHide
頁面重定向 調用API wx.redirectTo 或使用元件 onLoad,onShow onUnload
#頁面回傳 #呼叫API wx.navigateBack或用戶按左上角返回按鈕 onShow #onUnload
Tab切換 #多Tab 模式下用戶切換Tab 第一次開啟onLoad,onshow;否則onShow onHide

以上就是本文的全部內容,希望對大家的學習有幫助,更多相關內容請關注PHP中文網!

相關推薦:

微信小程式中wx:for和wx:for-item的用法

微信小程式-getUserInfo回呼的介紹

#

以上是微信小程式 Page()函數的介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中