微信小程序之上拉加載與下拉刷新

在移動端铭若,隨著手指不斷向上滑動洪碳,當(dāng)內(nèi)容將要到達(dá)屏幕底部的時候,頁面會隨之不斷的加載后續(xù)內(nèi)容叼屠,直到?jīng)]有新內(nèi)容為止(我們是有底線的-o-)瞳腌,我們稱之為上拉加載,從技術(shù)角度來說镜雨,也可以稱之為觸底加載嫂侍。

這種方式其實是PC端分頁瀏覽的一個分頁形式變種,很多PC網(wǎng)頁也會采用這種方式來進(jìn)行內(nèi)容分頁加載荚坞,以替代比較古老的1,2,3,4,5,6,7...分頁(稱之為有頁碼的分頁挑宠,這種分頁方式其實在一些場景下仍然是非常有用的,特別是在后臺管理系統(tǒng)頁面中需要精確抵達(dá)某一數(shù)據(jù)頁的場景)西剥。

另一種在移動端常見的操作痹栖,就是像在刷微博或微信朋友圈的時候,我想看看有沒有新的內(nèi)容出現(xiàn)瞭空,就會在頁面到頂?shù)臅r候揪阿,將頁面從上往下拖拉(這個時候頁頂通常會出現(xiàn)一個轉(zhuǎn)動的菊花之類的),然后放開手指咆畏,伴隨著一聲清脆的叮鈴咚隆聲南捂,頁面上呈現(xiàn)出了你朋友新鮮出爐的自拍照或雞湯文。

這種向下拖拉刷新的交互方式(簡稱下拉刷新)旧找,在移動端可以說是一種非常自然且方便的操作溺健,在現(xiàn)在的移動應(yīng)用中被廣泛采用。

好了钮蛛,上面簡要介紹了一下我們今天要關(guān)注的兩個交互方式鞭缭,目的當(dāng)然是要在微信小程序中來實現(xiàn)它們。其實魏颓,微信小程序提供的技術(shù)框架已經(jīng)為我們做了很多事情岭辣,讓這兩種交互實現(xiàn)起來變得相對很容易了。

下面我們就來一一講解具體的代碼實現(xiàn)甸饱。

上拉加載

前面我們已經(jīng)了解到下拉加載的本質(zhì)是一個分頁加載沦童,每次觸發(fā)加載下一頁的條件是當(dāng)前頁面到達(dá)底部,因此叹话,我們可以整理出一個實現(xiàn)的基本思路:

初始頁號為1偷遗,向后端請求第一頁數(shù)據(jù)(數(shù)據(jù)中包含數(shù)據(jù)總條數(shù),及當(dāng)前頁的數(shù)據(jù)數(shù)組)驼壶,返回后渲染該該頁數(shù)據(jù)

監(jiān)聽頁面是否被滾動到底部氏豌,是的話,則遞增頁號(+1)并向后端請求該新頁號的數(shù)據(jù)热凹,返回結(jié)果后泵喘,將該頁數(shù)據(jù)添加到之前已加載的數(shù)據(jù)后面瞭吃,并重新渲染

重復(fù)步驟2的操作

這個流程是不是很好理解?感覺實現(xiàn)起來也不難涣旨,主要就是其中的“監(jiān)聽頁面是否被滾動到底部”如何來實現(xiàn)?在Web頁面開發(fā)中股冗,我們會通過監(jiān)聽window.onscroll事件霹陡,在該事件的處理方法中獲取當(dāng)前頁的高度和滾動量,以此來計算判斷頁面是否已滾動到底止状。而在微信小程序中烹棉,我們并不需要自己來計算,小程序的Page已提供現(xiàn)成的監(jiān)聽用戶上拉觸底事件的處理函數(shù):onReachBottom怯疤,它會在頁面觸底的時候自動觸發(fā)(或在距離頁底一定距離的時候觸發(fā)浆洗,可設(shè)置)。

那么按照上面的原理集峦,實現(xiàn)出來的小程序代碼將會是什么樣子伏社?假設(shè)我們的例子是一個加載文章列表的頁面,下面是article.js代碼:

import{getArticles}from'../../services/article.service'Page({data:{page:1,pages:0,articles:[]},onLoad(options){// 頁面初次加載塔淤,請求第一頁數(shù)據(jù)this.fetchArticleList(1)},onReachBottom(){// 下拉觸底摘昌,先判斷是否有請求正在進(jìn)行中// 以及檢查當(dāng)前請求頁數(shù)是不是小于數(shù)據(jù)總頁數(shù),如符合條件高蜂,則發(fā)送請求if(!this.loading&&this.data.page<this.data.pages){this.fetchArticleList(this.data.page+1)}},fetchArticleList(pageNo){this.loading=true// 向后端請求指定頁碼的數(shù)據(jù)returngetArticles(pageNo).then(res=>{constarticles=res.itemsthis.setData({page:pageNo,//當(dāng)前的頁號pages:res.pages,//總頁數(shù)articles:this.data.articles.concat(articles)})}).catch(err=>{console.log("==> [ERROR]",err)}).then(()=>{this.loading=false})}})

從示例代碼中看到聪黎,我們發(fā)送和處理返回數(shù)據(jù)的函數(shù)主要就是fetchArticleList了,它分別在頁面初始化onLoad時被調(diào)用一次备恤,以及每次在上拉觸底觸發(fā)onReachBottom時被調(diào)用稿饰。

下拉刷新

再來說下拉刷新,在小程序里面實現(xiàn)起來可能比起上拉加載更簡單一些呢露泊。只要在小程序的全局配置文件app.json的window部分或在每個Page的同名配置文件里喉镰,加入一個值為true的enablePullDownRefresh配置項,并在需要處理下拉事件的Page代碼中加入onPullDownRefresh函數(shù)滤淳,就能開始接收下拉事件并進(jìn)行你自己的處理邏輯了梧喷,當(dāng)處理完成后,記得一定要調(diào)用wx.stopPullDownRefresh來終止下拉刷新脖咐。

我們?nèi)匀粊砀鶕?jù)上面的文章列表的例子铺敌,來實現(xiàn)下拉刷新:

首先是配置article.json:

{"enablePullDownRefresh":true}

然后在article.js中進(jìn)行如下改寫:

import{getArticles}from'../../services/article.service'Page({data:{page:1,pages:0,articles:[]},onLoad(options){// 頁面初次加載,請求第一頁數(shù)據(jù)this.fetchArticleList(1,true)},onReachBottom(){// 下拉觸底屁擅,先判斷是否有請求正在進(jìn)行中// 以及檢查當(dāng)前請求頁數(shù)是不是小于數(shù)據(jù)總頁數(shù)偿凭,如符合條件,則發(fā)送請求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// 向后端請求指定頁碼的數(shù)據(jù)returngetArticles(pageNo).then(res=>{constarticles=res.itemsthis.setData({page:pageNo,//當(dāng)前的頁號pages:res.pages,//總頁數(shù)articles:override?article:this.data.articles.concat(articles)})}).catch(err=>{console.log("==> [ERROR]",err)}).then(()=>{this.loading=false})}})

可以看到弯囊,我們增加了一個onPullDownRefresh函數(shù)并在里面調(diào)用了fetchArticleList去請求第一頁的數(shù)據(jù)痰哨,并且fetchArticleList函數(shù)也稍稍做了一下改動,加了一個參數(shù)override匾嘱,用于重置articles數(shù)據(jù)斤斧,而不是像上拉加載時那樣一直在原有數(shù)據(jù)后面進(jìn)行添加。

另外霎烙,下拉刷新的事件也可以通過調(diào)用APIwx.startPullDownRefresh觸發(fā)撬讽,效果與用戶手動下拉刷新一致。

其他

上面介紹的上拉加載和下拉刷新悬垃,都是針對整個Page的游昼。如果你需要局部的相應(yīng)功能,你可以嘗試使用<scroll-view>做容器尝蠕,并通過它的bindscrolltoupper和bindscrolltolower來監(jiān)聽內(nèi)容到頂或到底的事件烘豌,模擬實現(xiàn)出上拉加載和下拉刷新功能。

作者:一斤代碼

鏈接:http://www.reibang.com/p/d89e79d09e64

來源:簡書

著作權(quán)歸作者所有看彼。商業(yè)轉(zhuǎn)載請聯(lián)系作者獲得授權(quán)廊佩,非商業(yè)轉(zhuǎn)載請注明出處。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末靖榕,一起剝皮案震驚了整個濱河市罐寨,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌序矩,老刑警劉巖鸯绿,帶你破解...
    沈念sama閱讀 216,744評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異簸淀,居然都是意外死亡瓶蝴,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,505評論 3 392
  • 文/潘曉璐 我一進(jìn)店門租幕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來舷手,“玉大人,你說我怎么就攤上這事劲绪∧锌撸” “怎么了?”我有些...
    開封第一講書人閱讀 163,105評論 0 353
  • 文/不壞的土叔 我叫張陵贾富,是天一觀的道長忱叭。 經(jīng)常有香客問我赐纱,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,242評論 1 292
  • 正文 為了忘掉前任轴合,我火速辦了婚禮奔穿,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己春缕,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,269評論 6 389
  • 文/花漫 我一把揭開白布艘蹋。 她就那樣靜靜地躺著锄贼,像睡著了一般。 火紅的嫁衣襯著肌膚如雪女阀。 梳的紋絲不亂的頭發(fā)上咱娶,一...
    開封第一講書人閱讀 51,215評論 1 299
  • 那天,我揣著相機(jī)與錄音强品,去河邊找鬼。 笑死屈糊,一個胖子當(dāng)著我的面吹牛的榛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播逻锐,決...
    沈念sama閱讀 40,096評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼夫晌,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了昧诱?” 一聲冷哼從身側(cè)響起晓淀,我...
    開封第一講書人閱讀 38,939評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎盏档,沒想到半個月后凶掰,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,354評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡蜈亩,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,573評論 2 333
  • 正文 我和宋清朗相戀三年懦窘,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片稚配。...
    茶點故事閱讀 39,745評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡畅涂,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出道川,到底是詐尸還是另有隱情午衰,我是刑警寧澤,帶...
    沈念sama閱讀 35,448評論 5 344
  • 正文 年R本政府宣布冒萄,位于F島的核電站臊岸,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏尊流。R本人自食惡果不足惜扇单,卻給世界環(huán)境...
    茶點故事閱讀 41,048評論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望奠旺。 院中可真熱鬧蜘澜,春花似錦施流、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,683評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至装诡,卻和暖如春银受,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背鸦采。 一陣腳步聲響...
    開封第一講書人閱讀 32,838評論 1 269
  • 我被黑心中介騙來泰國打工宾巍, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人渔伯。 一個月前我還...
    沈念sama閱讀 47,776評論 2 369
  • 正文 我出身青樓顶霞,卻偏偏與公主長得像,于是被迫代替她去往敵國和親锣吼。 傳聞我的和親對象是個殘疾皇子选浑,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,652評論 2 354

推薦閱讀更多精彩內(nèi)容