欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用watch在微信小程序中實現(xiàn)全局狀態(tài)共享

 更新時間:2019年06月03日 11:21:25   作者:ma125120  
這篇文章主要給大家介紹了關(guān)于如何使用watch在小程序中實現(xiàn)全局狀態(tài)共享的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用微信小程序具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧

問題

在之前開發(fā)微信小程序的時候,獲取用戶信息、openid還有地理位置這些信息的時候,都是采用Promise的方式異步獲取,但是這樣的話在頁面和App.js中都獲取就可能造成請求重復(fù)的問題。

比如為了在每個頁面都能獲取到這些共享信息,都會選擇在App.js中進行獲取,然后在頁面級進行獲取,這兩次獲取的時間間隔較小時就可能導(dǎo)致前一個請求還未獲取到數(shù)據(jù),后一個請求就會再次進行獲取,這樣就產(chǎn)生了兩次請求。

還有一個問題就是書寫麻煩(雖然也能通過async await簡化),比如

onLoad() {
 app.getUserInfo()
 .then(userInfo => {
 
 }).catch(err => { /* 錯誤處理 */ });
 
 // 如果同時需要userInfo和openid,可能就是如下形式:
 Promise.all([app.getUserInfo(), app.getOpenid()])
 .then(res => {
 
 }).catch(err => { /* 錯誤處理 */ });
}

正好周末的時候突然想到了vue的watch語法,利用一些相關(guān)的知識,就可以解決這個麻煩的問題了。

解決思路

雙向綁定

vue的雙向綁定原理,3.0將會采用Proxy監(jiān)聽數(shù)據(jù)變化,不過考慮到小程序這邊的Proxy兼容性我不知道,所以采用了2.0的Object.defineProperty來監(jiān)聽數(shù)據(jù)的變化。

主要還是攔截設(shè)置的操作,在進行賦值時,將新舊值通知至監(jiān)聽者。

觀察者模式

在頁面級的onLoad監(jiān)聽app.globalData各個鍵名的事件,而在app.js的onLoad中則使用Object.defineProperty重新定義app.globalData,這樣一旦app.globalData相應(yīng)的鍵值發(fā)生了變化,就會通知監(jiān)聽的頁面該值發(fā)生了變化。

模塊化的引用

觀察者模式導(dǎo)出的是一個對象(類實例),而不是一個類,所以在導(dǎo)入的時候這個對象是共享的,就可以通過這個對象將app.js和其他頁面聯(lián)系起來。

至于模塊加載的實質(zhì),ES6模塊加載的機制,與CommonJS模塊完全不同。感興趣的可以去看看這個。

封裝Page

小程序的Page函數(shù)本身是不支持watch,但是我們可以自定義一個函數(shù),進行參數(shù)合并就可以了。

在頁面onLoad時先遍歷watch屬性,對app.globalData進行監(jiān)聽,可以參考vue的watch用法。

頁面onUnload時就會進行銷毀,此時也應(yīng)該取消監(jiān)聽,這些我都封裝過了,不用手動處理了。

有了這些思路,用不了多久,一個雛形就出來了,經(jīng)過手動測試,感覺沒什么問題,我就發(fā)布到npm了,大家感興趣的可以安裝體驗一下。

安裝

npm i wx-watch -S --production

使用

// app.js
var { watchData, } = require('/miniprogram_npm/wx-watch/index.js');

App({
 onLaunch() {
 this.watchData(); /* 監(jiān)聽this.globalData的變化,并觸發(fā)事件,其他頁面監(jiān)聽的值必須在globalData中預(yù)先定義,否則無法監(jiān)聽 */
 },
 watchData,
 globalData: {
 userInfo: null,
 }
});

// 其他需要監(jiān)聽globalData的頁面.js
var { getPage } = require('../../miniprogram_npm/wx-watch/index.js');
const app = getApp();

/**
 * getPage(頁面參數(shù),app) app必傳,因為封裝的時候訪問不到,就只能傳參了
*/
getPage({
 watch: {
 userInfo(userInfo, oldUserInfo) {
 console.log(`來自app.glodalData的userInfo`);
 }
 },
 // 其他參數(shù)
}, app)

github:  github.com/ma125120/wx

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。

相關(guān)文章

  • JS構(gòu)造函數(shù)與原型prototype的區(qū)別介紹

    JS構(gòu)造函數(shù)與原型prototype的區(qū)別介紹

    下面小編就為大家?guī)硪黄狫S構(gòu)造函數(shù)與原型prototype的區(qū)別介紹。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-07-07
  • js捕獲鼠標右鍵菜單中的粘帖事件實現(xiàn)代碼

    js捕獲鼠標右鍵菜單中的粘帖事件實現(xiàn)代碼

    突發(fā)奇想比如點擊菜單中的粘帖后事件如何捕獲,如下圖所示,用的jQuery中的paste事件,如想獲得粘帖文本要使用setTimeout控制下時間,感興趣的朋友可以參考下
    2013-04-04
  • 解決Layui中l(wèi)ayer報錯的問題

    解決Layui中l(wèi)ayer報錯的問題

    今天小編就為大家分享一篇解決Layui中l(wèi)ayer報錯的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • 詳細聊一聊js防抖節(jié)流到底是什么

    詳細聊一聊js防抖節(jié)流到底是什么

    在項目開發(fā)中我們常常會去監(jiān)聽滾動事件或者用戶輸入框驗證事件,如果事件處理沒有頻率限制,當用戶不斷觸發(fā)事件時,就會加重瀏覽器的負擔,影響用戶的體驗,造成不必要的損失,這篇文章主要給大家介紹了關(guān)于js防抖節(jié)流到底是什么的相關(guān)資料,需要的朋友可以參考下
    2022-04-04
  • 淺談js中的attributes和Attribute的用法與區(qū)別

    淺談js中的attributes和Attribute的用法與區(qū)別

    這篇文章主要介紹了淺談js中的attributes和Attribute的用法與區(qū)別,attributes可以獲取一個對象中的一個屬性,attributes 屬性返回指定節(jié)點屬性的集合,文中通過示例代碼介紹的非常詳細,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • js實現(xiàn)輪播圖自動切換

    js實現(xiàn)輪播圖自動切換

    這篇文章主要為大家詳細介紹了js實現(xiàn)輪播圖自動切換,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • js對象繼承之原型鏈繼承實例

    js對象繼承之原型鏈繼承實例

    這篇文章主要介紹了js對象繼承之原型鏈繼承,以實例形式分析了原型鏈繼承的實現(xiàn)方法與注意事項,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-01-01
  • js實現(xiàn)登錄拖拽窗口

    js實現(xiàn)登錄拖拽窗口

    這篇文章主要為大家詳細介紹了js實現(xiàn)登錄拖拽窗口,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • prototype與__proto__區(qū)別詳細介紹

    prototype與__proto__區(qū)別詳細介紹

    這篇文章主要介紹了prototype與__proto__區(qū)別詳細介紹的相關(guān)資料,需要的朋友可以參考下
    2017-01-01
  • js原生日歷的實例(推薦)

    js原生日歷的實例(推薦)

    下面小編就為大家?guī)硪黄猨s原生日歷的實例(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10

最新評論