Vue實現(xiàn)渲染數(shù)據(jù)后控制滾動條位置(推薦)
需求場景如下:
實現(xiàn)了消息發(fā)送,如果容器內(nèi)消息過多,會出現(xiàn)滾動條,最新的消息位于最底部,不能及時出現(xiàn)在可視區(qū)域內(nèi),此時就需要在渲染列表后,將滾動條的位置定位到最底部。先來看看最終實現(xiàn)的效果
實現(xiàn)思路
- 渲染完數(shù)據(jù)后,通過refs對象獲取消息容器的實際高度
- 將滾動條的設(shè)置到最底部
實現(xiàn)過程
sendMessage: function (event) { // 數(shù)據(jù)渲染 this.senderMessageList.push(thisSenderMessageObj); // 改變滾動條位置 this.messagesContainerTimer = setTimeout(()=>{ this.$refs.messagesContainer.scrollTop = this.$refs.messagesContainer.scrollHeight; console.log("當(dāng)前滾動條位置:"+this.$refs.messagesContainer.scrollTop); console.log("當(dāng)前可滾動區(qū)域容器的高度:"+this.$refs.messagesContainer.scrollHeight); // 清理定時器 clearTimeout(this.messagesContainerTimer); },0); }
踩坑記錄
直接設(shè)置滾動條的位置
數(shù)據(jù)渲染完成后直接獲取元素的真實高度,設(shè)置滾動條的位置,講道理好像沒什么毛病,結(jié)果滾動條的高度沒有預(yù)想的渲染。問題原因:數(shù)據(jù)渲染完成后,Vue此時還沒有渲染DOM元素,設(shè)置的滾動條高度還是之前的容器高度。
sendMessage: function (event) { // 數(shù)據(jù)渲染 this.senderMessageList.push(thisSenderMessageObj); // 改變滾動條位置 this.$refs.messagesContainer.scrollTop = this.$refs.messagesContainer.scrollHeight; console.log("當(dāng)前滾動條位置:"+this.$refs.messagesContainer.scrollTop); console.log("當(dāng)前可滾動區(qū)域容器的高度:"+this.$refs.messagesContainer.scrollHeight); }
正確的改變方式: 使用setTimeout(),將DOM操作改為異步。
this.messagesContainerTimer = setTimeout(()=>{ this.$refs.messagesContainer.scrollTop = this.$refs.messagesContainer.scrollHeight; console.log("當(dāng)前滾動條位置:"+this.$refs.messagesContainer.scrollTop); console.log("當(dāng)前可滾動區(qū)域容器的高度:"+this.$refs.messagesContainer.scrollHeight); // 清理定時器 clearTimeout(this.messagesContainerTimer); },0);
總結(jié)
以上所述是小編給大家介紹的Vue實現(xiàn)渲染數(shù)據(jù)后控制滾動條位置,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
vue實現(xiàn)點(diǎn)擊出現(xiàn)操作彈出框的示例
這篇文章主要介紹了vue實現(xiàn)點(diǎn)擊出現(xiàn)操作彈出框的示例,幫助大家更好的理解和使用vue,感興趣的朋友可以了解下2020-11-11Vue nextTick延遲回調(diào)獲取更新后DOM機(jī)制詳解
這篇文章主要為大家介紹了Vue nextTick延遲回調(diào)獲取更新后DOM機(jī)制詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08vue如何設(shè)置輸入框只能輸入數(shù)字且只能輸入小數(shù)點(diǎn)后兩位,并且不能輸入減號
這篇文章主要介紹了vue如何設(shè)置輸入框只能輸入數(shù)字且只能輸入小數(shù)點(diǎn)后兩位,并且不能輸入減號問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-05-05Vue包大小優(yōu)化的實現(xiàn)(從1.72M到94K)
這篇文章主要介紹了Vue包大小優(yōu)化的實現(xiàn)(從1.72M到94K),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02