溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

微信小程序如何實(shí)現(xiàn)滾動(dòng)加載數(shù)據(jù)

發(fā)布時(shí)間:2021-01-28 10:46:25 來(lái)源:億速云 閱讀:228 作者:小新 欄目:移動(dòng)開發(fā)

這篇文章給大家分享的是有關(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小菊花用的

需要用到的屬性

微信小程序如何實(shí)現(xiàn)滾動(dòng)加載數(shù)據(jù)

scrol-view需要指定一個(gè)高度,這個(gè)高度可以按自己的需求計(jì)算,我使用的是屏幕可用高度并且默認(rèn)一頁(yè)顯示6個(gè)

微信小程序如何實(shí)現(xiàn)滾動(dòng)加載數(shù)據(jù)

滾動(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ò),可以把它分享出去讓更多的人看到吧!

向AI問(wèn)一下細(xì)節(jié)

免責(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)容。

AI