在移動端,隨著手指不斷向上滑動,當內容將要到達屏幕底部的時候,頁面會隨之不斷的加載后續內容,直到沒有新內容為止(我們是有底線的-o-),我們稱之為上拉加載,從技術角度來說,也可以稱之為觸底加載。
這種方式其實是PC端分頁瀏覽的一個分頁形式變種,很多PC網頁也會采用這種方式來進行內容分頁加載,以替代比較古老的1,2,3,4,5,6,7...分頁(稱之為有頁碼的分頁,這種分頁方式其實在一些場景下仍然是非常有用的,特別是在后臺管理系統頁面中需要精確抵達某一數據頁的場景)。
另一種在移動端常見的操作,就是像在刷微博或微信朋友圈的時候,我想看看有沒有新的內容出現,就會在頁面到頂的時候,將頁面從上往下拖拉(這個時候頁頂通常會出現一個轉動的菊花之類的),然后放開手指,伴隨著一聲清脆的叮鈴咚隆聲,頁面上呈現出了你朋友新鮮出爐的自拍照或雞湯文。
這種向下拖拉刷新的交互方式(簡稱下拉刷新),在移動端可以說是一種非常自然且方便的操作,在現在的移動應用中被廣泛采用。
好了,上面簡要介紹了一下我們今天要關注的兩個交互方式,目的當然是要在微信小程序中來實現它們。其實,微信小程序提供的技術框架已經為我們做了很多事情,讓這兩種交互實現起來變得相對很容易了。
下面我們就來一一講解具體的代碼實現。
上拉加載
前面我們已經了解到下拉加載的本質是一個分頁加載,每次觸發加載下一頁的條件是當前頁面到達底部,因此,我們可以整理出一個實現的基本思路:
初始頁號為1,向后端請求第一頁數據(數據中包含數據總條數,及當前頁的數據數組),返回后渲染該該頁數據
監聽頁面是否被滾動到底部,是的話,則遞增頁號(+1)并向后端請求該新頁號的數據,返回結果后,將該頁數據添加到之前已加載的數據后面,并重新渲染
重復步驟2的操作
這個流程是不是很好理解?感覺實現起來也不難,主要就是其中的“監聽頁面是否被滾動到底部”如何來實現?在Web頁面開發中,我們會通過監聽window.onscroll事件,在該事件的處理方法中獲取當前頁的高度和滾動量,以此來計算判斷頁面是否已滾動到底。而在微信小程序中,我們并不需要自己來計算,小程序的Page已提供現成的監聽用戶上拉觸底事件的處理函數:onReachBottom,它會在頁面觸底的時候自動觸發(或在距離頁底一定距離的時候觸發,可設置)。
那么按照上面的原理,實現出來的小程序代碼將會是什么樣子?假設我們的例子是一個加載文章列表的頁面,下面是article.js代碼:
import { getArticles } from '../../services/article.service'
Page({
data: {
page: 1,
pages: 0,
articles: []
},
onLoad(options) {
// 頁面初次加載,請求第一頁數據 this.fetchArticleList(1)
},
onReachBottom() {
// 下拉觸底,先判斷是否有請求正在進行中 // 以及檢查當前請求頁數是不是小于數據總頁數,如符合條件,則發送請求 if (!this.loading && this.data.page < this.data.pages) {
this.fetchArticleList(this.data.page + 1)
}
},
fetchArticleList(pageNo) {
this.loading = true // 向后端請求指定頁碼的數據 return getArticles(pageNo).then(res => {
const articles = res.items
this.setData({
page: pageNo, //當前的頁號
pages: res.pages, //總頁數
articles: this.data.articles.concat(articles)
})
}).catch(err => {
console.log("==> [ERROR]", err)
}).then(() => {
this.loading = false
})
}
})
從示例代碼中看到,我們發送和處理返回數據的函數主要就是fetchArticleList了,它分別在頁面初始化onLoad時被調用一次,以及每次在上拉觸底觸發onReachBottom時被調用。
下拉刷新
再來說下拉刷新,在小程序里面實現起來可能比起上拉加載更簡單一些呢。只要在小程序的全局配置文件app.json的window部分或在每個Page的同名配置文件里,加入一個值為true的enablePullDownRefresh配置項,并在需要處理下拉事件的Page代碼中加入onPullDownRefresh函數,就能開始接收下拉事件并進行你自己的處理邏輯了,當處理完成后,記得一定要調用wx.stopPullDownRefresh來終止下拉刷新。
我們仍然來根據上面的文章列表的例子,來實現下拉刷新:
首先是配置article.json:
{
"enablePullDownRefresh": true
}
然后在article.js中進行如下改寫:
import { getArticles } from '../../services/article.service'
Page({
data: {
page: 1,
pages: 0,
articles: []
},
onLoad(options) {
// 頁面初次加載,請求第一頁數據 this.fetchArticleList(1, true)
},
onReachBottom() {
// 下拉觸底,先判斷是否有請求正在進行中 // 以及檢查當前請求頁數是不是小于數據總頁數,如符合條件,則發送請求 if (!this.loading && this.data.page < this.data.pages) {
this.fetchArticleList(this.data.page + 1)
}
},
onPullDownRefresh() {
// 上拉刷新 if (!this.loading) {
this. fetchArticleList(1, true).then(() => {
// 處理完成后,終止下拉刷新
wx.stopPullDownRefresh()
})
}
},
fetchArticleList(pageNo, override) {
this.loading = true // 向后端請求指定頁碼的數據 return getArticles(pageNo).then(res => {
const articles = res.items
this.setData({
page: pageNo, //當前的頁號
pages: res.pages, //總頁數
articles: override ? article : this.data.articles.concat(articles)
})
}).catch(err => {
console.log("==> [ERROR]", err)
}).then(() => {
this.loading = false
})
}
})
可以看到,我們增加了一個onPullDownRefresh函數并在里面調用了fetchArticleList去請求第一頁的數據,并且fetchArticleList函數也稍稍做了一下改動,加了一個參數override,用于重置articles數據,而不是像上拉加載時那樣一直在原有數據后面進行添加。
另外,下拉刷新的事件也可以通過調用APIwx.startPullDownRefresh觸發,效果與用戶手動下拉刷新一致。
其他
上面介紹的上拉加載和下拉刷新,都是針對整個Page的。如果你需要局部的相應功能,你可以嘗試使用<scroll-view>做容器,并通過它的bindscrolltoupper和bindscrolltolower來監聽內容到頂或到底的事件,模擬實現出上拉加載和下拉刷新功能。
本文來源于成都網站建設公司與成都網站設計制作公司-創新互聯成都公司!
當前標題:微信小程序之上拉加載與下拉刷新
路徑分享:http://vcdvsql.cn/news18/310718.html
成都網站建設公司_創新互聯,為您提供企業建站、全網營銷推廣、外貿建站、軟件開發、移動網站建設、外貿網站建設
廣告
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源:
創新互聯