JS使用虛擬列表查看微信聊天記錄功能技巧實例
PC端 微信聊天記錄查看
這個功能是pc端程序,實現(xiàn)手機端微信聊天記錄查看功能
功能問題點
1,默認(rèn)看到的記錄是倒序排列,頁面最底下一條是最近一條消息
2,聊天記錄可能存在無限往上翻閱的情況,dom無法承載如此多消息,需要使用虛擬列表
3, 向上向下翻閱過程中,滑動到上一頁或者下一頁如何定位當(dāng)前頁面最后一條第一條在當(dāng)前,絲滑加載,不出現(xiàn)‘閃跳’情況
4,動態(tài)加載,考慮接口性能,一次請求數(shù)據(jù)不能太多,如何維護整個消息列表信息
一,消息記錄數(shù)據(jù)結(jié)構(gòu)
需要一個msgData
字段來存儲所有從接口返回來的消息,{data,random}
隨機數(shù)用于表示數(shù)據(jù)向下傳遞時表示是更新,初始值是0,每一條消息都有一個msgId
字段,用于標(biāo)識當(dāng)前收到的消息記錄中歷史最遠(yuǎn)的一條記錄id。消息上滑下滑根據(jù)滑動方向,以及msgId
可以判斷是從內(nèi)存取數(shù)據(jù)還是額外請求接口。
二,數(shù)據(jù)展示
傳入的random
字段用于標(biāo)識是第一次傳入還是數(shù)據(jù)更新,如果是第一次傳入,新建一個宏任務(wù),計算傳入數(shù)據(jù)展示成相應(yīng)元素之后的高度,
const virtualItems = document.getElementById('vir-scroll'); virtualItems.scrollTop = timeFilter ? 0 : virtualItems.scrollHeight; // 如果timefilter 為真,scroll到頂部 currentScroll = timeFilter ? 0 : virtualItems.scrollHeight;
如果是更新,需要計算目前內(nèi)存中數(shù)據(jù)條數(shù)(數(shù)量小于顯示界面數(shù)據(jù)閾值就追加)以及滾動方向,來獲取相應(yīng)的顯示數(shù)據(jù)。
計算過程中,累加元素的getBoundingClientRect().height
來計算當(dāng)前展示元素的高度,計算高度的同時,還需要把對應(yīng)的dom元素渲染到頁面中。
滾動
const scrollTop = virtualRef.current.scrollTop; direction = scrollTop < currentScroll ? 'down' : 'up'; currentDirection = direction; currentScroll = scrollTop; // 計算滾動條到底部距離,保證異步加載元素位置不變的關(guān)鍵 bottomDistance = virtualRef.current.scrollHeight - virtualRef.current.clientHeight - virtualRef.current.scrollTop; const lastMsgId = direction === 'up' ? +items[items.length - 1]?.key : +items[0]?.key; const indx = wrapperData?.data?.findIndex((elm:any) => elm.msgTime === lastMsgId);
滾動時需要計算當(dāng)前滾動方向,根據(jù)方向再進(jìn)行下面的計算,這里需要分為上滑和下滑。
下滑到底時,如果距離頂部小于50,就要觸發(fā)計算,根據(jù)當(dāng)前頁面元素第一條的索引值去內(nèi)存中找15條,當(dāng)前頁面元素尾部去掉15條重新拼湊成需要展示到頁面的完整數(shù)據(jù),然后計算出scrollHeight
,實現(xiàn)順滑滑動。
上滑到頂,距離底部小于50,觸發(fā)計算,計算方式和下滑相反。
以上就是JS使用虛擬列表查看微信聊天記錄功能技巧實例的詳細(xì)內(nèi)容,更多關(guān)于JS虛擬列表查看微信聊天記錄的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
webpack-bundle-analyzer?插件配置使用方法
webpack-bundle-analyzer?是?webpack?的插件,需要配合?webpack?和?webpack-cli?一起使用,這篇文章主要介紹了webpack-bundle-analyzer?插件配置,需要的朋友可以參考下2023-02-02JavaScript數(shù)組操作之旋轉(zhuǎn)二維數(shù)組
這篇文章主要介紹了JavaScript數(shù)組操作之旋轉(zhuǎn)二維數(shù)組,主要從兩個方面展開文章介紹,一是通過對數(shù)組的操作熟練度;二是(鏡像反轉(zhuǎn))比實現(xiàn)一更優(yōu),減少了空間復(fù)雜度,內(nèi)容介紹具有一定的參考價值,需要的小伙伴可以參考一下2022-04-04基于JavaScript實現(xiàn)手機短信按鈕倒計時(超簡單)
在淘寶等購物網(wǎng)站,我們都會看到一個發(fā)送短信倒計時的按鈕,究竟是如何實現(xiàn)的呢?下面小編通過本篇文章給大家分享一段代碼關(guān)于js實現(xiàn)手機短信按鈕倒計時,需要的朋友參考下2015-12-12