欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

怎么讓你的小程序健步如飛

這篇文章給大家分享的是有關(guān)怎么讓你的小程序健步如飛的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。

在沁水等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場(chǎng)前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)、外貿(mào)網(wǎng)站建設(shè) 網(wǎng)站設(shè)計(jì)制作按需策劃,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站設(shè)計(jì),全網(wǎng)整合營(yíng)銷推廣,外貿(mào)營(yíng)銷網(wǎng)站建設(shè),沁水網(wǎng)站建設(shè)費(fèi)用合理。

通過(guò)這種技術(shù),可以縮短用戶的等待時(shí)間,極大地提升用戶的使用體驗(yàn)。由于那篇文章并未給出實(shí)現(xiàn)方式,只是講解了技術(shù)原理,因此本文就來(lái)為大家講下技術(shù)實(shí)現(xiàn)方式。

框架優(yōu)缺點(diǎn)

優(yōu)點(diǎn):

  • 預(yù)加載下一個(gè)頁(yè)面的數(shù)據(jù),提高了頁(yè)面的加載速度,輕量級(jí)的協(xié)議(200~300ms左右就能接收到數(shù)據(jù))能輕松讓小程序頁(yè)面打開后數(shù)據(jù)瞬間加載,幾乎不出現(xiàn)空頁(yè)面。

  • 讓同種業(yè)務(wù)的代碼保持在一個(gè)類中,不會(huì)破壞項(xiàng)目結(jié)構(gòu)。

  • 代碼量非常少,對(duì)原本業(yè)務(wù)影響非常少。

  • 實(shí)現(xiàn)預(yù)加載后想刪掉預(yù)加載?只需在實(shí)現(xiàn)的類中刪除一個(gè)字符串即可。

缺點(diǎn):

  • 需要你按情況替換setData為$setData

  • 需要開發(fā)者非常清楚各情況下的上下文是什么。

  • 如果你的協(xié)議非常耗時(shí),達(dá)到400ms以上的,使用這種優(yōu)化方式效果就不明顯了。

  • 有網(wǎng)友發(fā)現(xiàn),這個(gè)項(xiàng)目無(wú)法運(yùn)行在使用了組件的小程序中,所以大家如果使用了組件的話,就不要直接用這個(gè)項(xiàng)目 了。不過(guò)還是推薦你吸收下這個(gè)項(xiàng)目的思想,畢竟工程師在工作中思想是很重要的。

這里就不為大家展示最終效果了,感興趣的朋友可以自行嘗試下。

如何集成

重要聲明:我的小程序是遵循ES6標(biāo)準(zhǔn)寫的,里面用了class extends及解構(gòu)賦值等,如果看不懂的話,請(qǐng)學(xué)習(xí)下ES6?。∪绻愕捻?xiàng)目是用的ES5,那就仔細(xì)閱讀后續(xù)文章,體會(huì)預(yù)加載技術(shù)的核心思想,如果核心思想理解了,分分鐘寫一個(gè)出來(lái),對(duì)吧 ~ ~

首先,你要有個(gè)基類CommonPage

小程序中的每一個(gè)Page類都繼承該基類,這樣的話才方便統(tǒng)一管理。

比如下面的IndexPage頁(yè)面

// 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是第一個(gè)頁(yè)面,不需要預(yù)加載,SecondPage是第二個(gè)頁(yè)面,我們來(lái)模擬下SecondPage的預(yù)加載方式。

接下來(lái)看到的this.$route() this.$put() this.$take() this.$resolve() this.$reject()等帶$符號(hào)的都是基類中實(shí)現(xiàn)的方法。

1、給IndexPage頁(yè)面添加跳轉(zhuǎn)按鈕。

<!--index.wxml-->
<view class="container">
    <view bindtap="toSecondPage" hover-class="press-style" class="normal-style" hover-stay-time="100"> 閃電加載第二個(gè)頁(yè)面</view>
    <view>300毫秒 閃電加載方式</view>
</view>

注意:這里添加的class="normal-style" hover-stay-time="100"是非常重要的,如果不添加點(diǎn)擊態(tài),會(huì)很影響體驗(yàn)。

2、給IndexPage頁(yè)面添加預(yù)加載專用跳轉(zhuǎn)方式。

 toSecondPage = function () {
        // this.$route是預(yù)加載的頁(yè)面跳轉(zhuǎn)方式,以wx.navigateTo方式跳轉(zhuǎn)。這個(gè)方法是在CommonPage中實(shí)現(xiàn)的。
        this.$route({path: '../second/second', query: {count: 10, title: '這是第二個(gè)頁(yè)面'}, clazzName: 'SecondPage'});
		
		// 這是小程序原生的普通加載方式
        // wx.navigateTo({
        //     url: '../second/second?count=10&title=這是第二個(gè)頁(yè)面'
        // })
    }

this.$route({path, query, clazzName});這個(gè)方法的參數(shù)含義是:

  • path:頁(yè)面路徑,支持絕對(duì)路徑和相對(duì)路徑。

  • query:需要傳遞的參數(shù)。這是一個(gè)object類型的。

  • clazzName:需要跳轉(zhuǎn)的頁(yè)面的類名。這個(gè)介紹SecondPage時(shí)再說(shuō)。

其實(shí)你可能會(huì)問(wèn),既然有path了,為什么還要clazzName?這個(gè)問(wèn)題會(huì)在介紹技術(shù)原理時(shí)詳細(xì)說(shuō),那是下一篇的事兒了。

到這里,如果你也是用ES6的規(guī)范來(lái)實(shí)現(xiàn)類的,可以看到,在IndexPage中,你只需將跳轉(zhuǎn)方式修改為this.$route({path, query, clazzName});即可。

3、給SecondPage頁(yè)面添加預(yù)加載專用的初始化方法。

// pages/second/second.js
import CommonPage from "../CommonPage";
class SecondPage extends CommonPage {
    constructor(...args) {
	    //super(...args)一定要寫,他會(huì)將clazzName與下面的data進(jìn)行合并。
        super(...args);
        //這個(gè)$init(obj)中注入的obj就是頁(yè)面初始時(shí)的data
        super.$init({
            arr: []
        });
    }

    $onNavigator(query) {
	    //這里的query是從this.$route中傳遞來(lái)的query
        console.log('閃電?加載時(shí)接收到的參數(shù)', query);
        this.$put('second-data', this.initData.bind(this), query);
    };
	
    initData = function (query, resolve, reject) {
	    //這里的query是在this.$put()中傳遞過(guò)來(lái)的
	    //resolve在協(xié)議成功時(shí)回調(diào)
	    //reject在協(xié)議失敗時(shí)回調(diào)
	    //模擬網(wǎng)絡(luò)請(qǐng)求
        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}個(gè)`, 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)用時(shí)觸發(fā) data就是resolve傳遞的參數(shù)
                this.$setData(data);
            },(data, error)=>{
	            //失敗回調(diào),reject(data, error)調(diào)用時(shí)觸發(fā),data和error是reject傳遞的參數(shù)。
            });
            return;
        }
        this.initData(options);
    }
}
//這里注入的clazzName: 'SecondPage',與this.$route({path, query, clazzName});中的clazzName名稱與其一致即可
Page(new SecondPage({clazzName: 'SecondPage'}));

大概是這么幾步:

  • 這個(gè)類需要在new時(shí),將clazzName注入,this.$route({path, query, clazzName});中的clazzName名稱與其一致即可。

  • 需要在SecondPage中注入新的生命周期函數(shù),也就是預(yù)加載方法。在執(zhí)行this.$route時(shí),你在this.$route中傳遞的clazzName是什么,這個(gè)框架就會(huì)自動(dòng)去找匹配一致的類,調(diào)用該類的$onNavigator方法。

  • 在$onNavigator中調(diào)用this.$put(key,fun,query)參數(shù)分別是鍵、異步請(qǐng)求方法、異步請(qǐng)求方法的參數(shù)。

  • 在異步請(qǐng)求方法將this.setData替換為this.$setData(),使用this.$resolve(data)或者this.$reject(data,error)來(lái)回調(diào)成功或失敗。

  • 在onLoad中使用this.$take(key).then(success,fail)來(lái)獲取異步結(jié)果,分別對(duì)應(yīng)了resolve和reject回調(diào)。如果你沒(méi)有使用預(yù)加載,或者預(yù)加載失敗,那么this.$take(key)方法返回空,由此可以判斷是否使用了預(yù)加載進(jìn)入頁(yè)面!

這么做的話,實(shí)現(xiàn)了在跳轉(zhuǎn)前先把下一個(gè)頁(yè)面的協(xié)議發(fā)出去,而且還讓同種業(yè)務(wù)的代碼保持在一個(gè)類中,不會(huì)破壞項(xiàng)目結(jié)構(gòu)!

在實(shí)現(xiàn)了預(yù)加載后,如果不想用預(yù)加載了,只需要?jiǎng)h掉new SecondPage()時(shí)注入的clazzName即可!

感謝各位的閱讀!關(guān)于“怎么讓你的小程序健步如飛”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

新聞標(biāo)題:怎么讓你的小程序健步如飛
轉(zhuǎn)載來(lái)源:http://aaarwkj.com/article48/gpiiep.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化小程序開發(fā)、搜索引擎優(yōu)化、外貿(mào)建站、靜態(tài)網(wǎng)站網(wǎng)站設(shè)計(jì)公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)
欧美成人黄片免费播放| 成年人正常性生活频率| 亚洲高清有码在线观看| 老熟妇仑乱换频一区二区| 免费看夫妻性生活视频| 国产精精精精品欧美日韩| 欧美一级特黄免费大片| 西西美女掰开阴让你看| 麻豆人妻少妇精品毛片| 亚洲综合一区国产精品| 日本免费一区二区三区视频观看 | 另类视频网站在线观看| 亚洲精品一区二区三区三州| 精品久久久久久亚洲电影| 最新国产av网址大全| 小黄片免费在线播放观看| 国产大片在线观看一区二区| 91中文字幕国产日韩| 91天美精东果冻麻豆| 亚洲国产成人一区二区精品区| 加勒比人妻一区二区三区| 天堂av在线一区二区三区| 侵犯人妻中文字幕一区二区| 亚洲伦理在线一区二区| 国产传媒在线视频观看| 亚洲丰满熟女乱一区二区三区| 黄色av一本二本在线观看| 黄色av福利在线网站| 日韩国产一区二区三区精品| 国产经典三级在线观看| 婷婷综合伊人久久狠狠| 91精品国产综合久久麻豆| 日本国产美女精品一区二区| 亚洲欧美成人高清在线观看| 国产另类极品熟女露脸自拍| 要爽死国产一区在线播放| 极品人妻视频中文字幕| 中文字幕四虎在线观看| 国产熟女一区二区三区正在| 国产偷国产偷亚洲综合av| 91在线播放国产视频|