Vue3实现滚动条自动滚动到底部
作者:水果摊见
在Vue中,通过ref和watch结合nextTick实现滚动区域自动滚动到底部,并添加返回顶部按钮,适用于动态内容场景,供开发者参考
需求
在一个区域会依次打印log,随着log的加长,出现滚动条,而滚动条应该始终保持在最下方。
点击回到顶部按钮,可以使滚动条回到最上方
方案
- 在滚动区域添加ref
- log为一个数组,对其添加watch
- 在watch函数中,使用nextTick,通过ref控制该区域滚动高度
- 绑定ref,监测其height,使回到顶部按钮出现,并通过ref控制滚动条回到顶部
代码
// template <div class="bottom-logs" ref="logRef"> // antd vue中的back-top组件 <a-back-top :target="() => logRef" :visibilityHeight="10" @click="handleBackToTop" /> <LogData :logData="log"></LogData> </div> // css // 父级元素 display: flex .bottom-logs { flex: 1; overflow: auto; }
<script setup> import { ref, watch, nextTick } from 'vue' const logRef = ref(); // log为响应式数组 watch(log, () => { nextTick(() => { const content = logRef.value; content.scrollTo({ top: content.scrollHeight, behavior: "smooth" }); }); }, { deep: true, }); const handleBackToTop = () => { const content = logRef.value; content.scrollTo({ top: 0, behavior: "smooth" }); } </script>
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。