您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)微信小程序如何實(shí)現(xiàn)滾動(dòng)加載數(shù)據(jù)的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。
操作事件函數(shù),主要是將請(qǐng)求下來(lái)的數(shù)據(jù)用concat方法進(jìn)行合并,然后賦值,我是用的for循環(huán)假裝添加的數(shù)據(jù),實(shí)際項(xiàng)目中可以換成自己的ajax
需要用到的組件和api
scroll-view(可滾動(dòng)視圖區(qū)域)
wx.showToast(OBJECT)顯示消息提示窗----顯示loading小菊花用的
需要用到的屬性
scrol-view需要指定一個(gè)高度,這個(gè)高度可以按自己的需求計(jì)算,我使用的是屏幕可用高度并且默認(rèn)一頁(yè)顯示6個(gè)
滾動(dòng)到底部綁定需要觸發(fā)的事件
操作事件函數(shù),主要是將請(qǐng)求下來(lái)的數(shù)據(jù)用concat方法進(jìn)行合并,然后賦值,我是用的for循環(huán)假裝添加的數(shù)據(jù),實(shí)際項(xiàng)目中可以換成自己的ajax,并且為了模擬加載我添加了一個(gè)1.5秒的定時(shí)器,先調(diào)用提示框api成功之后關(guān)閉
lower() { var result = this.data.res; var resArr = []; ??//這里可以使用自己的ajax for (let i = 0; i < 10; i++) { resArr.push(i); }; var cont = result.concat(resArr);//合并請(qǐng)求的數(shù)據(jù) console.log(resArr.length); if (cont.length >= 100) { wx.showToast({ //期間為了顯示效果可以添加一個(gè)過(guò)度的彈出框提示“加載中” title: \'我也是有底線的\', icon: \'success\', duration: 300 }); return false; } else { wx.showLoading({ //期間為了顯示效果可以添加一個(gè)過(guò)度的彈出框提示“加載中” title: \'加載中\(zhòng)', icon: \'loading\', }); setTimeout(() => { this.setData({ res: cont }); wx.hideLoading(); }, 1500) } }
成功,放完整代碼可以直接復(fù)制運(yùn)行
js代碼
Page({ /** * 頁(yè)面的初始數(shù)據(jù) */ data: { height: \'\', res: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] }, lower() { var result = this.data.res; var resArr = []; for (let i = 0; i < 10; i++) { resArr.push(i); }; var cont = result.concat(resArr); console.log(resArr.length); if (cont.length >= 100) { wx.showToast({ //如果全部加載完成了也彈一個(gè)框 title: \'我也是有底線的\', icon: \'success\', duration: 300 }); return false; } else { wx.showLoading({ //期間為了顯示效果可以添加一個(gè)過(guò)度的彈出框提示“加載中” title: \'加載中\(zhòng)', icon: \'loading\', }); setTimeout(() => { this.setData({ res: cont }); wx.hideLoading(); }, 1500) } }, /** * 生命周期函數(shù)--監(jiān)聽(tīng)頁(yè)面加載 */ onLoad: function (options) { wx.getSystemInfo({ success: (res) => { this.setData({ height: res.windowHeight }) } }) } })
感謝各位的閱讀!關(guān)于“微信小程序如何實(shí)現(xiàn)滾動(dòng)加載數(shù)據(jù)”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。