Vue實(shí)現(xiàn)渲染數(shù)據(jù)后控制滾動(dòng)條位置(推薦)
需求場(chǎng)景如下:
實(shí)現(xiàn)了消息發(fā)送,如果容器內(nèi)消息過多,會(huì)出現(xiàn)滾動(dòng)條,最新的消息位于最底部,不能及時(shí)出現(xiàn)在可視區(qū)域內(nèi),此時(shí)就需要在渲染列表后,將滾動(dòng)條的位置定位到最底部。先來看看最終實(shí)現(xiàn)的效果
實(shí)現(xiàn)思路
- 渲染完數(shù)據(jù)后,通過refs對(duì)象獲取消息容器的實(shí)際高度
- 將滾動(dòng)條的設(shè)置到最底部
實(shí)現(xiàn)過程
sendMessage: function (event) {
// 數(shù)據(jù)渲染
this.senderMessageList.push(thisSenderMessageObj);
// 改變滾動(dòng)條位置
this.messagesContainerTimer = setTimeout(()=>{
this.$refs.messagesContainer.scrollTop = this.$refs.messagesContainer.scrollHeight;
console.log("當(dāng)前滾動(dòng)條位置:"+this.$refs.messagesContainer.scrollTop);
console.log("當(dāng)前可滾動(dòng)區(qū)域容器的高度:"+this.$refs.messagesContainer.scrollHeight);
// 清理定時(shí)器
clearTimeout(this.messagesContainerTimer);
},0);
}
踩坑記錄
直接設(shè)置滾動(dòng)條的位置
數(shù)據(jù)渲染完成后直接獲取元素的真實(shí)高度,設(shè)置滾動(dòng)條的位置,講道理好像沒什么毛病,結(jié)果滾動(dòng)條的高度沒有預(yù)想的渲染。問題原因:數(shù)據(jù)渲染完成后,Vue此時(shí)還沒有渲染DOM元素,設(shè)置的滾動(dòng)條高度還是之前的容器高度。
sendMessage: function (event) {
// 數(shù)據(jù)渲染
this.senderMessageList.push(thisSenderMessageObj);
// 改變滾動(dòng)條位置
this.$refs.messagesContainer.scrollTop = this.$refs.messagesContainer.scrollHeight;
console.log("當(dāng)前滾動(dòng)條位置:"+this.$refs.messagesContainer.scrollTop);
console.log("當(dāng)前可滾動(dòng)區(qū)域容器的高度:"+this.$refs.messagesContainer.scrollHeight);
}

正確的改變方式: 使用setTimeout(),將DOM操作改為異步。
this.messagesContainerTimer = setTimeout(()=>{
this.$refs.messagesContainer.scrollTop = this.$refs.messagesContainer.scrollHeight;
console.log("當(dāng)前滾動(dòng)條位置:"+this.$refs.messagesContainer.scrollTop);
console.log("當(dāng)前可滾動(dòng)區(qū)域容器的高度:"+this.$refs.messagesContainer.scrollHeight);
// 清理定時(shí)器
clearTimeout(this.messagesContainerTimer);
},0);
總結(jié)
以上所述是小編給大家介紹的Vue實(shí)現(xiàn)渲染數(shù)據(jù)后控制滾動(dòng)條位置,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
- 解決Vue頁面固定滾動(dòng)位置的處理辦法
- vue實(shí)現(xiàn)滾動(dòng)條到頂部或者到指定位置
- vue中實(shí)現(xiàn)點(diǎn)擊按鈕滾動(dòng)到頁面對(duì)應(yīng)位置的方法(使用c3平滑屬性實(shí)現(xiàn))
- vue監(jiān)聽頁面中的某個(gè)div的滾動(dòng)事件并判斷滾動(dòng)的位置
- Vue滾動(dòng)到指定位置的多種方式示例詳解
- Vue滾動(dòng)頁面到指定位置的實(shí)現(xiàn)及避坑
- Vue列表如何實(shí)現(xiàn)滾動(dòng)到指定位置樣式改變效果
- 解決vue無法設(shè)置滾動(dòng)位置的問題
- vue通過滾動(dòng)行為實(shí)現(xiàn)從列表到詳情,返回列表原位置的方法
- vue-scroller記錄滾動(dòng)位置的示例代碼
- Vue頁面返回滾動(dòng)位置恢復(fù)(keep-alive滾動(dòng)記憶)
相關(guān)文章
vue3+echarts+折線投影(陰影)效果的實(shí)現(xiàn)
這篇文章主要介紹了vue3+echarts+折線投影(陰影)效果的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10
Vue?Axios請(qǐng)求取消和重發(fā)封裝的實(shí)現(xiàn)代碼
這篇文章主要介紹了Vue?Axios請(qǐng)求取消和重發(fā)的封裝的實(shí)現(xiàn),文章通過代碼示例講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-09-09
vue前端和Django后端如何查詢一定時(shí)間段內(nèi)的數(shù)據(jù)
這篇文章主要給大家介紹了關(guān)于vue前端和Django后端如何查詢一定時(shí)間段內(nèi)的數(shù)據(jù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02
vue3封裝Element導(dǎo)航菜單的實(shí)例代碼
這篇文章主要介紹了vue3封裝Element導(dǎo)航菜單的實(shí)例代碼,分為菜單數(shù)據(jù)格式示例,控制導(dǎo)航收縮的詳細(xì)代碼,本文通過實(shí)例代碼介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧2024-03-03
vue3 攜帶參數(shù)跳轉(zhuǎn)|router傳參方式
這篇文章主要介紹了vue3 攜帶參數(shù)跳轉(zhuǎn)|router傳參方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06

