最近開始針對項目性全面學習了一點js,和同事一起用MUI寫了個項目,就敢拿出來獻丑,我也是diaodiao的。經(jīng)過幾十個工時業(yè)余時間*(最近兩周有點忙,周期拖得有點長,本來計劃五一之前發(fā)出來的) ,在 仿知乎微信小程序demo 基礎(chǔ)上,結(jié)合玩Android開源API,完成了玩Android小程序版的初版 (和群里基佬們做得比感覺做的太簡單了,大家就當練練手)*,掃碼或者關(guān)注微信公眾號 Android精推 即可體驗:
本項目主要包含以下幾大模塊:
先上預覽圖:
為什么要寫這個?學了點js就飄了,群里大佬們寫的都是Android版本的,微信小程序大家似乎都有接觸但是可能都覺得比較簡單,也是為了便于手持iPhone的基佬們隨時點贊刷玩Android。
寫方法體還是一樣
function formatNumber(n) { n = n.toString() return n[1] ? n : '0' + n } 復制代碼
或者
function getData(url) { XXXXXX } 復制代碼
都和我們原生js寫法、jquery等幾乎一致,然鵝要注意一點就是如果該方法需要外部調(diào)用,需要多加一個:
module.exports = { formatTime: formatTime }; 復制代碼
在文件里加上這個,或者也可以寫成:
module.exports.getData = getData; 復制代碼
data: { motto: 'Hello World', userInfo: {}, wanUserName: '登錄玩Android賬戶', } 復制代碼
而我們經(jīng)過數(shù)據(jù)處理以后,需要實時更新頁面則可以直接調(diào)用:
//更新數(shù)據(jù) that.setData({ userInfo: userInfo }) 復制代碼
對,就是鍵值對的方式,和data一樣。這里需要注意的是 that 這個,我們一般會在方法體內(nèi)部先var一個參數(shù)that去獲取全局實例 this ,這樣避免方法自己的實例取代了頁面的全局實例。this代表著當前對象,會隨著程序的執(zhí)行過程中的上下文改變,例如在wx.request({});方法的回調(diào)函數(shù)中,對象已經(jīng)發(fā)生改變,所以已經(jīng)不是wx.request({});方法對象了,data屬性也不存在了。
那么在微信小程序里我們怎么管理頁面呢。微信小程序固然沒有AMS這些東西,那么我們可以判斷page來管理:
// 返回上個頁面 setTimeout(function () { wx.navigateBack({ delta: 1 }) }, 1500); 復制代碼
這里我設置了一個延遲,核心的代碼是wx.navigateBack(),這里面的參數(shù)delta指的是退回頁面的層數(shù),比如我這里是返回上一頁,那么值就是1,以此類推。。。但是我們一般返回上個頁面的時候也會帶一定的參數(shù),這里就有三種*(可能更多) 介紹給大家: 1、利用本地存儲 (類似Android的sp)*方式存儲起來,這里去看看官方文檔很簡單,都是wx.XXX的。 2、利用生命周期傳遞,例如:
var pages = getCurrentPages(); var currPage = pages[pages.length - 1]; //當前頁面 var prevPage = pages[pages.length - 2]; //上一個頁面 //直接調(diào)用上一個頁面的setData()方法,把數(shù)據(jù)存到上一個頁面中去 prevPage.setData({ mydata: {a:1, b:2} }) 復制代碼
這里是在簡書的 微信小程序從子頁面退回父頁面時的數(shù)據(jù)傳遞 學習到的。這種方式在邏輯上要清晰得多,也不存在對數(shù)據(jù)的銷毀有額外的管理工作,看起來十分優(yōu)雅,從一定的角度說類似于Android的ActivityForResult方式。當然有利也是有弊的,比如使用這個頁面的有多個入口,這樣做很可能會導致獲取到的頁面實例不正確。當然如果對于邏輯層次簡單的、耦合少的頁面還是比較方便的。
3、使用fire傳遞,這個方式是類似于我們EventBus的方式,后面有詳解。
之前說到,fire是一個非常輕量級的第三方的組件庫,在微信小程序限制項目大小2MB的情況下,在js調(diào)用中可以實現(xiàn)類似EventBus的全局事件訂閱管理,非常簡單好用。 1、首先,導fire文件,這個去網(wǎng)上下載一個*(不到1KB)*就可以,直接把onfire.js文件拷過來。 2、寫訂閱事件和接受者的時候:
是不是一毛一樣的?不僅僅在微信小程序中,包括vue、React等都可以使用,具體使用*(無非是一行代碼發(fā)送消息,接收消息的時候?qū)懸粋€方法)*可以去自行百度。
焦點沖突什么的在Android里面問題多多,在這里就要簡單太多了。之前我曾嘗試使用Android的方式去做,發(fā)現(xiàn)總是碰壁。無奈又要求助一波百度*(文檔看的太少)*。在點擊事件的時候,我們一般是給被點擊View添加一個bindtap方法,后面寫上方法名即可:
bindtap="bindItemTap" 復制代碼
而如果這個View里面包含了其他的子View需要添加點擊事件的時候,我們需要使用另一種寫法了:
catchtap="clickCollect" 復制代碼
這里的點擊事件也很有趣,包括手指的手勢都有涉及,包括手指點下去的時候、抬起來的時候、移動的時候等等,和Android的ACTION_DOWN及 ACTION_UP等異曲同工。
提到微信的url限制,不得不說微信目前限制個人開發(fā)者和海外開發(fā)者使用webview打開第三方h5頁面。所以,咱們在預覽的時候只能用編譯器去預覽,想看具體的文章目前還是有限制的,我就不求贊助申請企業(yè)認證了。當然也歡迎有企業(yè)賬戶的基佬把代碼fork過去給大家提供個福利*(別犯法哦)*。
工作日 8:30-12:00 14:30-18:00
周六及部分節(jié)假日提供值班服務