這篇文章給大家分享的是有關(guān)微信小程序如何實(shí)現(xiàn)上滑加載下拉刷新的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。
頁(yè)面緩存的設(shè)置優(yōu)化了頁(yè)面加載,減少了頻繁的調(diào)取接口,使用戶在斷網(wǎng)的情況下有更好的體驗(yàn)。
每個(gè)微信小程序都可以有自己的本地緩存,可以通過(guò) wx.setStorage(wx.setStorageSync)、wx.getStorage(wx.getStorageSync)、wx.clearStorage(wx.clearStorageSync)可以對(duì)本地緩存進(jìn)行設(shè)置、獲取和清理。本地緩存大為10MB。
注意: localStorage 是永久存儲(chǔ)的,但是我們不建議將關(guān)鍵信息全部存在 localStorage,以防用戶換設(shè)備的情況。
項(xiàng)目需求
通過(guò)使用scroll-view 自定義的鼠標(biāo)滾動(dòng)事件onscrollLower,監(jiān)聽(tīng)頁(yè)面下拉事件
page.init()的方法里封裝了請(qǐng)求數(shù)據(jù)的接口,后臺(tái)api文檔自帶分頁(yè)pageSize,默認(rèn)值為10,-1為請(qǐng)求全部數(shù)據(jù)。
說(shuō)明:
觸發(fā)下滑事件通過(guò)與頁(yè)面data緩存數(shù)據(jù)對(duì)比,去請(qǐng)求接口。
代碼實(shí)現(xiàn)
var n=0 page.init = function(callback) { page.data.loading = true; n+=10; cardService.listFavoriteCards(n,function(result){ var cards = result.data.favoriteCards; var starCards = result.data.starCards; starCards.sort(function(c1,c2){ var c1Name = pinyingUtil.getInitials.convertPinyin(c1.name); var c2Name = pinyingUtil.getInitials.convertPinyin(c2.name); return c1Name > c2Name ? 1 : -1; }); if(starCards && starCards.length> 0) { starCards.forEach(function(c){ var compressEntName = dictService.compressEntName(c.companyName); c.compressEntName = compressEntName; }); } page.setData({ "favoriteCards" : cards, "starCards" : starCards, "filterType" : "name", "groups" : cardService.groupCardsByNameFirstLetter(cards), "loadding":false }); wx.setStorageSync("setgroups",page.data.groups) }); }; }
onLoad: function (options) { var geigroups=wx.getStorageSync('setgroups') var result =[] for(var i=0; i<geigroups.length; i+=5){ result.push(geigroups.slice(i,i+5)); } var resultd=result[0] if(geigroups){ page.setData({ "groups" : resultd }); console.log('緩存') }else{ if (wx.getStorageSync("token")) { page.init(); page.initProfile(); } else { App.addListener("evt_login", function () { page.init(); page.initProfile(); }); } console.log('正常') } }
onscrollLower:function(){ var page = this; var geigroups=wx.getStorageSync('setgroups') //第一步拿數(shù)據(jù) var result =[] //定義空數(shù)組 var n=0; //定義index for(var i=0; i<geigroups.length; i+=10){ result.push(geigroups.slice(i,i+10)); } //把數(shù)據(jù)每10個(gè)一組push到 result里面 n+=1; var q=this.data.groups.length; if(geigroups){ //如果有緩存 if(geigroups.length<=q) //如果當(dāng)前data的數(shù)據(jù)少于緩存執(zhí)行以下命令 if (wx.getStorageSync("token")) { //如果有token請(qǐng)求數(shù)據(jù) page.init(); page.initProfile(); } else { App.addListener("evt_login", function () { //監(jiān)聽(tīng)用戶登陸以后 請(qǐng)求數(shù)據(jù) page.init(); page.initProfile(); }); } }else{ page.setData({ "groups" : result[n], }); } },
總結(jié)
加載數(shù)據(jù)的幾種方法:
方法一:onPullDownRefresh和onReachBottom方法實(shí)現(xiàn)小程序下拉加載和上拉刷新
方法二:在scroll-view里設(shè)定bindscrolltoupper和bindscrolltolower實(shí)現(xiàn)微信小程序下拉
感謝各位的閱讀!關(guān)于“微信小程序如何實(shí)現(xiàn)上滑加載下拉刷新”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站chinadenli.net,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
當(dāng)前名稱:微信小程序如何實(shí)現(xiàn)上滑加載下拉刷新-創(chuàng)新互聯(lián)
文章位置:http://chinadenli.net/article42/dhjihc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)、企業(yè)網(wǎng)站制作、標(biāo)簽優(yōu)化、響應(yīng)式網(wǎng)站、網(wǎng)站內(nèi)鏈、外貿(mào)建站
聲明:本網(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)
猜你還喜歡下面的內(nèi)容