Vue设置滚动条自动保持到最底端

7,199次阅读
没有评论

共计 584 个字符,预计需要花费 2 分钟才能阅读完成。

需求描述:在开发中我们常常会遇到需要让滚动条保持到最底端的需求,比如在开发一个聊天框时,请求接口拿到消息列表数据,展示到前端页面时,需要让滚动条自动滚到最底端,以此来展示最后的聊天记录。同时,当发送一条新的消息时,也需要滚动条自动滚动到最底端,默认显示到最后一条数据,而不是在发送完一条新消息之后还需要手动滑动滚动条到最底端。

主要实现原理:

其实这个需求就是需要设置该元素(产生滚动条的元素)的scrollTop 等于scrollHeight

主要代码:

template>
	div ref="box" class="box">div>
template>
script>
	
	scrollToBottom() {
	  
	  const box = this.$refs.box as HTMLElement
	  this.$nextTick(() => {
	    box.scrollTop = box.scrollHeight
	  })
	}
script>
style>
.box {
	overflow: auto;
	height: 446px;  
 }
 style>

注意事项:

box 容器必须设置具体的高度 height,否则不会产生滚动条,(如果页面上看有滚动条,那可能是父元素产生的滚动条),如果没有给 box 容器设置高度的话,这个scrollToBottom 方法就不会生效!

如果本篇博客对你有帮助,请点个赞吧 o(~▽~)d

原文地址: Vue 设置滚动条自动保持到最底端

    正文完
     0
    Yojack
    版权声明:本篇文章由 Yojack 于2024-10-23发表,共计584字。
    转载说明:
    1 本网站名称:优杰开发笔记
    2 本站永久网址:https://yojack.cn
    3 本网站的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,请联系站长进行删除处理。
    4 本站一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
    5 本站所有内容均可转载及分享, 但请注明出处
    6 我们始终尊重原创作者的版权,所有文章在发布时,均尽可能注明出处与作者。
    7 站长邮箱:laylwenl@gmail.com
    评论(没有评论)