|
發(fā)布時間:2021-03-15 10:49:32
來源:億速云
閱讀:103
作者:小新
欄目:移動開發(fā) 這篇文章給大家分享的是有關(guān)怎么讓你的小程序健步如飛的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。 通過這種技術(shù),可以縮短用戶的等待時間,極大地提升用戶的使用體驗。由于那篇文章并未給出實現(xiàn)方式,只是講解了技術(shù)原理,因此本文就來為大家講下技術(shù)實現(xiàn)方式。 框架優(yōu)缺點 優(yōu)點:
缺點:
這里就不為大家展示最終效果了,感興趣的朋友可以自行嘗試下。 如何集成 重要聲明:我的小程序是遵循ES6標(biāo)準(zhǔn)寫的,里面用了class extends及解構(gòu)賦值等,如果看不懂的話,請學(xué)習(xí)下ES6?。∪绻愕捻椖渴怯玫腅S5,那就仔細(xì)閱讀后續(xù)文章,體會預(yù)加載技術(shù)的核心思想,如果核心思想理解了,分分鐘寫一個出來,對吧 ~ ~ 首先,你要有個基類CommonPage 小程序中的每一個Page類都繼承該基類,這樣的話才方便統(tǒng)一管理。 比如下面的IndexPage頁面 // pages/index/index.js
import CommonPage from "../CommonPage";
class IndexPage extends CommonPage {
constructor(...args) {
super(...args);
this.data = {
testStr: this is the firstPage
}
}
onLoad(options) {
}
}
Page(new IndexPage());IndexPage是第一個頁面,不需要預(yù)加載,SecondPage是第二個頁面,我們來模擬下SecondPage的預(yù)加載方式。 接下來看到的this.$route() this.$put() this.$take() this.$resolve() this.$reject()等帶$符號的都是基類中實現(xiàn)的方法。 1、給IndexPage頁面添加跳轉(zhuǎn)按鈕。 <!--index.wxml--> <view class="container"> <view bindtap="toSecondPage" hover-class="press-style" class="normal-style" hover-stay-time="100"> 閃電加載第二個頁面</view> <view>300毫秒 閃電加載方式</view> </view> 注意:這里添加的class="normal-style" hover-stay-time="100"是非常重要的,如果不添加點擊態(tài),會很影響體驗。 2、給IndexPage頁面添加預(yù)加載專用跳轉(zhuǎn)方式。 toSecondPage = function () {
// this.$route是預(yù)加載的頁面跳轉(zhuǎn)方式,以wx.navigateTo方式跳轉(zhuǎn)。這個方法是在CommonPage中實現(xiàn)的。
this.$route({path: ../second/second, query: {count: 10, title: 這是第二個頁面}, clazzName: SecondPage});
// 這是小程序原生的普通加載方式
// wx.navigateTo({
// url: ../second/second?count=10&title=這是第二個頁面
// })
}this.$route({path, query, clazzName});這個方法的參數(shù)含義是:
其實你可能會問,既然有path了,為什么還要clazzName?這個問題會在介紹技術(shù)原理時詳細(xì)說,那是下一篇的事兒了。 到這里,如果你也是用ES6的規(guī)范來實現(xiàn)類的,可以看到,在IndexPage中,你只需將跳轉(zhuǎn)方式修改為this.$route({path, query, clazzName});即可。 3、給SecondPage頁面添加預(yù)加載專用的初始化方法。 // pages/second/second.js
import CommonPage from "../CommonPage";
class SecondPage extends CommonPage {
constructor(...args) {
//super(...args)一定要寫,他會將clazzName與下面的data進(jìn)行合并。
super(...args);
//這個$init(obj)中注入的obj就是頁面初始時的data
super.$init({
arr: []
});
}
$onNavigator(query) {
//這里的query是從this.$route中傳遞來的query
console.log(閃電?加載時接收到的參數(shù), query);
this.$put(second-data, this.initData.bind(this), query);
};
initData = function (query, resolve, reject) {
//這里的query是在this.$put()中傳遞過來的
//resolve在協(xié)議成功時回調(diào)
//reject在協(xié)議失敗時回調(diào)
//模擬網(wǎng)絡(luò)請求
setTimeout(() => {
if (typeof query.count === "string") {
query.count = parseInt(query.count);
}
this.data.arr.splice(0, this.data.arr.length);
for (let i = 0; i < query.count; i++) {
this.data.arr.push({id: i, name: `第${i}個`, age: parseInt(Math.random() * 20 + i)})
}
this.$setData(this.data);
this.$resolve(this.data);//或者 resolve(this.data);只有調(diào)用了resolve或者reject方法,才能在this.$take()的then()方法中獲取到值。
}, 300);
};
onLoad(options) {
const lightningData = this.$take(second-data);
if (lightningData) {
lightningData.then((data) => {
//成功回調(diào),resolve(data)調(diào)用時觸發(fā) data就是resolve傳遞的參數(shù)
this.$setData(data);
},(data, error)=>{
//失敗回調(diào),reject(data, error)調(diào)用時觸發(fā),data和error是reject傳遞的參數(shù)。
});
return;
}
this.initData(options);
}
}
//這里注入的clazzName: SecondPage,與this.$route({path, query, clazzName});中的clazzName名稱與其一致即可
Page(new SecondPage({clazzName: SecondPage}));大概是這么幾步:
這么做的話,實現(xiàn)了在跳轉(zhuǎn)前先把下一個頁面的協(xié)議發(fā)出去,而且還讓同種業(yè)務(wù)的代碼保持在一個類中,不會破壞項目結(jié)構(gòu)! 在實現(xiàn)了預(yù)加載后,如果不想用預(yù)加載了,只需要刪掉new SecondPage()時注入的clazzName即可! 感謝各位的閱讀!關(guān)于“怎么讓你的小程序健步如飛”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧! |
|
|