交互設(shè)計(jì)中的數(shù)據(jù)加載
前陣子設(shè)計(jì)一款從0到1的產(chǎn)品,到了測(cè)試環(huán)節(jié),突然有同學(xué)提了一下數(shù)據(jù)加載的問題。對(duì)于數(shù)據(jù)加載的問題,我一直是一個(gè)模糊的狀態(tài)。因?yàn)槟:?,所以進(jìn)行設(shè)計(jì)時(shí)經(jīng)常模棱兩可,這次一定要把數(shù)據(jù)加載搞清楚。
一、理解數(shù)據(jù)加載對(duì)我們有什么幫助
弄清楚數(shù)據(jù)加載可以讓我們?cè)诤线m的業(yè)務(wù)場(chǎng)景使用恰當(dāng)?shù)募虞d方式,就像擁有一個(gè)工具箱,知道什么工具可以做什么事,事半功倍。
同時(shí),做好數(shù)據(jù)加載可以讓我們的用戶降低等待焦慮,獲得更好的用戶體驗(yàn)。
二、加載和刷新
加載:指的是請(qǐng)求更多的數(shù)據(jù)
刷新:指的是請(qǐng)求最新的數(shù)據(jù)
這兩個(gè)場(chǎng)景結(jié)合「知乎」應(yīng)該更好理解,你可以通過下拉刷新來獲取最新的推薦問題,也可以通過上滑查看更多的數(shù)據(jù):
三、數(shù)據(jù)加載的場(chǎng)景
1. 從后臺(tái)切回應(yīng)用
涉及到跨平臺(tái)任務(wù)的場(chǎng)景,當(dāng)切回過程是很短的間隔則無需數(shù)據(jù)加載,超過一定時(shí)間間隔可以設(shè)定追加事件刷新。
2. 啟動(dòng)App
當(dāng)應(yīng)用出現(xiàn)異常關(guān)閉、應(yīng)用閃退等情況需要重新啟動(dòng)app,需要進(jìn)行數(shù)據(jù)加載。
3. 觸發(fā)加載事件
一般包含兩種情況:用戶手動(dòng)觸發(fā)、系統(tǒng)自動(dòng)加載。
用戶手動(dòng)觸發(fā):也就是常見的下拉刷新和上滑加載,也包含點(diǎn)擊按鈕重新加載。
系統(tǒng)自動(dòng)加載:當(dāng)前內(nèi)容展示完畢,預(yù)加載下一頁內(nèi)容。
4. 頁面跳轉(zhuǎn)
涉及頁面跳轉(zhuǎn),可能是原生跳轉(zhuǎn)原生頁面,也能可以原生跳轉(zhuǎn)到h5頁面。
既然都有頁面跳轉(zhuǎn),加載新數(shù)據(jù)是必然的。
5. 定時(shí)數(shù)據(jù)刷新
在特定時(shí)間內(nèi),頁面會(huì)進(jìn)行刷新和數(shù)據(jù)加載,運(yùn)營活動(dòng)居多。
例如排行榜每天23:59更新,亦或是某些限時(shí)活動(dòng),這里我找了一個(gè)最近支付寶消費(fèi)券的例子。
6. 即時(shí)消息推送
微信的消息采用實(shí)時(shí)推送機(jī)制,不需要用戶手動(dòng)刷新和加載。
這就是微信小程序的入口可以大膽地做到一個(gè)下拉刷新位置的原因。
四、數(shù)據(jù)加載方式
在具體介紹數(shù)據(jù)加載方式的基礎(chǔ)之前先明確兩個(gè)加載邏輯:懶加載和預(yù)加載。
- 懶加載:顧名思義,懶模式,進(jìn)入頁面時(shí),再加載數(shù)據(jù)。
- 預(yù)加載:預(yù)加載數(shù)據(jù),再展示頁面。
大部分場(chǎng)景使用的是懶加載,節(jié)約性能,但是預(yù)加載能提前預(yù)測(cè)用戶的瀏覽行為,保證體驗(yàn)。
1. 整體加載
整體加載是指加載所有內(nèi)容后再展現(xiàn)給用戶,具體的表現(xiàn)形式是空白頁加載。
- 優(yōu)點(diǎn):能保證內(nèi)容的整體性,不會(huì)造成信息缺失。
- 缺點(diǎn):非常容易造成等待焦慮。
2. 分布加載
分布加載也成為優(yōu)先加載,將頁面內(nèi)容重要的部分提前加載出來,具體的表現(xiàn)形式有:分塊加載、分頁加載和分屏加載。
(1)分塊加載
可以根據(jù)數(shù)據(jù)類型進(jìn)行先后加載,如資訊類應(yīng)用,優(yōu)先加載文字而后加載圖片。
優(yōu)點(diǎn):可以保證用戶快速獲取內(nèi)容。
缺點(diǎn):部分內(nèi)容因?yàn)榧虞d速度限制而被用戶忽略,從而造成信息缺失。
(2)分頁加載
對(duì)于一些列表或卡片信息,可以使用自動(dòng)或手動(dòng)的分頁加載。
優(yōu)點(diǎn):可以較快地展示比較完整的內(nèi)容。
缺點(diǎn):可能會(huì)對(duì)信息檢索造成一定影響。
(3)分屏加載
先加載出全局頁面框架,而后隨頁面停留,再具體加載相應(yīng)內(nèi)容。
優(yōu)點(diǎn):節(jié)省資源,方便聚焦內(nèi)容。
缺點(diǎn):只適用一些數(shù)據(jù)量較大的頁面,信息不滿足。
3. 智能加載
智能加載通過用戶的網(wǎng)絡(luò)狀態(tài)選擇不同加載方案。
非WiFi模式下:暫不加載資源,提示用戶需要耗費(fèi)流量,等用戶確認(rèn)后進(jìn)行加載
WIFI模式下:自動(dòng)加載所有資源
優(yōu)點(diǎn):比較貼心,適用于視頻、音樂等需要占用比較大流量的產(chǎn)品
缺點(diǎn):會(huì)造成路徑訪問的阻滯。
4. 緩存加載
也就是過去提到的離線加載,通過現(xiàn)有Wifi資源將服務(wù)器內(nèi)容緩存到本地,無網(wǎng)絡(luò)或是弱網(wǎng)環(huán)境下讀取緩存加載。
優(yōu)點(diǎn):可以解決無網(wǎng)或弱網(wǎng)情況下數(shù)據(jù)獲取的問題
缺點(diǎn):可能會(huì)占用本地的存儲(chǔ)空間,以及后續(xù)的緩存處理需要考慮。
5. 漸進(jìn)式加載
點(diǎn)擊圖片會(huì)先看到高斯模糊的圖片,然后加載詳細(xì)圖片。
優(yōu)點(diǎn):降低等待,節(jié)省資源。
缺點(diǎn):使用必須根據(jù)數(shù)據(jù)類型,有一定局限性。
五、加載設(shè)計(jì)流程
數(shù)據(jù)加載的業(yè)務(wù)流程并不復(fù)雜。具體如下:
分支情況:沒有更多新內(nèi)容、空頁面、頁面被刪除。
異常情況:網(wǎng)絡(luò)連接異常、刷新過于頻繁、網(wǎng)絡(luò)狀態(tài)切換、服務(wù)器崩潰。
加載功能點(diǎn):下拉刷新、點(diǎn)擊刷新、系統(tǒng)自動(dòng)刷新、重新加載按鈕等。
六、加載優(yōu)化策略
數(shù)據(jù)加載流程的優(yōu)化可以通過兩個(gè)維度來進(jìn)行優(yōu)化:
1. 交互層面優(yōu)化
(1)盡可能考慮預(yù)加載
使用預(yù)加載可能極大提高用戶體驗(yàn),而消耗的性能卻并不算多。
(2)使用異步處理
某些關(guān)鍵頁面可以采用異步處理數(shù)據(jù),等恢復(fù)網(wǎng)絡(luò)環(huán)境的時(shí)候再與服務(wù)器校對(duì)。具有一定的門檻和風(fēng)險(xiǎn),需要技術(shù)評(píng)估后使用。
(3)使用緩存
需要注意數(shù)據(jù)存儲(chǔ)的數(shù)據(jù)類型、更新規(guī)則,配合緩存加載可以讓用戶降低等待,又不會(huì)用占用大量的本地存儲(chǔ)空間。
(4)盡量使用非模態(tài)加載
非模態(tài)地加載:不會(huì)打擾用戶,可以讓用戶轉(zhuǎn)移注意力而降低等待焦慮。
模態(tài)加載:只能完成當(dāng)前加載后其他的事,原生應(yīng)用內(nèi)使用模態(tài),一定要考慮提供取消按鈕,提供給用戶掌控權(quán)。
(5)提前加載布局
在一些不太需要完整性的頁面,盡量先將頁面布局展示出來。
(6)進(jìn)度條顯示
應(yīng)用內(nèi)打開H5頁面盡量提供進(jìn)度條,先慢后快,盡可能消減用戶等待焦慮。
2. UI層面優(yōu)化
(1)加載動(dòng)畫
使用情感化加載動(dòng)畫,可以讓等待過程變得輕松、愉悅。
(2)加載占位圖
如一些品牌元素,可以讓用戶在使用過程中加深對(duì)應(yīng)用的印象,形成品牌感知。
(3)加載色塊
如一些圖片瀑布流應(yīng)用,花瓣網(wǎng)、Pinterst,則會(huì)采用圖片色塊流的形式優(yōu)先展示底色,降低等待焦慮。
因?yàn)楸救斯ατ邢?,?duì)數(shù)據(jù)加載的理解止步于此,歡迎各位同學(xué)積極探討,相互交流成長!
參考資料:
6種常見加載方式的優(yōu)缺點(diǎn)及設(shè)計(jì)策略
作者:瓦解Pen;公眾號(hào):否定設(shè)計(jì)師,歡迎關(guān)注,一起成長!
本文由 @瓦解Pen 原創(chuàng)發(fā)布于人人都是產(chǎn)品經(jīng)理。未經(jīng)許可,禁止轉(zhuǎn)載
題圖來自Unsplash,基于CC0協(xié)議
收藏了,平時(shí)就是懶于總結(jié)
干貨滿滿,收益了
動(dòng)態(tài)加載 學(xué)習(xí)了
這里的總結(jié)僅在功能設(shè)計(jì)層面~
干貨,可以深挖的東西比多多
哈哈 這是一個(gè)工具箱, 你可以根據(jù)自己場(chǎng)景使用
看完了!謝謝作者
不用謝,將知識(shí)轉(zhuǎn)化為自己的。
1
Mark么?