如何在Vue中实现类似微信聊天记录的向上滚动加载功能而不让滚动条自动回到顶部?

如何在vue中实现类似微信聊天记录的向上滚动加载功能而不让滚动条自动回到顶部?

Vue.js实现微信式聊天记录向上滚动加载,滚动条位置不变

本文介绍如何在Vue.js中构建类似微信聊天记录的向上滚动加载功能,避免滚动条自动回滚到顶部。

现有代码已实现向上滚动加载更多记录,但新数据加载后,滚动条会回到顶部。为了解决这个问题,我们需要记录滚动位置,并在加载新数据后恢复该位置。

改进后的代码如下:

  
  • {{ item }}
import { createApp, ref, nextTick } from 'https://lf9-cdn-tos.bytecdntp.com/cdn/expire-1-ms/vue/3.2.31/vue.esm-browser.prod.min.js';function generateNumbers(start, end) { if (!Number.isInteger(start) || !Number.isInteger(end)) { throw new Error('Start and end must be integers.'); } if (start > end) { throw new Error('Start must be less than or equal to end.'); } return Array.from({ length: end - start + 1 }, (_, i) => start + i);}createApp({ setup() { const msgs = ref(generateNumbers(1, 200)); const chatListRef = ref(null); let prevScrollTop = 0; // 新增:记录之前的滚动条位置 const scrollToBottom = async () => { const chatListElement = chatListRef.value; if (chatListElement) { chatListElement.scrollTop = chatListElement.scrollHeight; } }; const handleScroll = (ev) => { const target = ev.target; prevScrollTop = target.scrollTop; // 新增:记录滚动条位置 if (target.scrollTop === 0) { const scrollHeightBefore = target.scrollHeight; msgs.value.unshift(...generateNumbers(msgs.value.length + 1, msgs.value.length + 200)); nextTick(() => { const scrollHeightAfter = target.scrollHeight; target.scrollTop = scrollHeightAfter - scrollHeightBefore + prevScrollTop; // 恢复滚动条位置 }); } }; nextTick(() => scrollToBottom()); return { msgs, chatListRef, handleScroll }; },}).mount('#app');* { margin: 0; padding: 0;}html,body { height: 100vh; background-color: #e9f5f8;}.container { width: 200px; height: 500px; overflow-y: auto; background-color: #fff;}

关键改进:

立即学习“前端免费学习笔记(深入)”;

添加 prevScrollTop 变量记录之前的滚动条位置。在 handleScroll 中,每次滚动时都更新 prevScrollTop。加载新数据后,使用 nextTick 确保 DOM 更新完成,然后计算并设置新的 scrollTop 值,使其保持在加载数据前的相对位置。 target.scrollTop = scrollHeightAfter - scrollHeightBefore + prevScrollTop; 这行代码计算了需要调整的滚动距离,确保滚动条位置不变。

通过这些修改,实现了在向上滚动加载新数据时,滚动条位置保持不变的效果,提升用户体验。 代码也使用了更简洁的 Array.from 方法生成数字序列。

以上就是如何在Vue中实现类似微信聊天记录的向上滚动加载功能而不让滚动条自动回到顶部?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1503582.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月20日 02:05:20
下一篇 2025年12月20日 02:05:40

相关推荐

  • 如何实现一个支持协同编辑的文本区域?

    答案:实现协同编辑需实时同步多用户操作并解决冲突,主要采用OT或CRDT技术。通过WebSocket传输操作,结合Yjs等库管理状态,实现光标共享、断线重连与权限控制,确保最终一致性。 要实现一个支持协同编辑的文本区域,核心在于实时同步多个用户之间的编辑操作,并解决并发冲突。这通常通过“操作变换”(…

    2025年12月20日
    000
  • 解决Electron-vite预览空白屏问题:HashRouter的应用

    electron-vite项目在构建成功后,执行预览命令时可能出现空白屏幕。本文深入探讨了这一常见问题,指出其根源在于前端路由模式的选择。通过将react应用中的browserrouter替换为hashrouter,可以有效解决此问题,确保electron-vite项目在预览和生产环境中正常显示内容…

    2025年12月20日
    000
  • 实现JavaScript动态列表拖放功能

    在现代Web应用中,动态生成和管理列表元素是常见的需求。当这些列表需要支持用户通过拖放来重新排序时,开发者可能会遇到一个挑战:如何让动态创建的元素响应拖放事件?特别是当使用insertAdjacentHTML()这类方法批量插入HTML字符串时,直接为每个新元素添加事件监听器会变得复杂且效率低下。 …

    2025年12月20日
    000
  • JavaScript动态更新元素内容:一个逐步教程

    本文详细讲解了如何使用 JavaScript 动态更新 HTML 元素的内容,重点是如何正确获取输入框的值并将其添加到新创建的元素中。同时,也介绍如何利用表单简化代码,以及如何使用 localStorage 持久化存储数据,并提供相应的代码示例和最佳实践。 动态更新元素内容的基础方法 核心问题在于如…

    2025年12月20日
    000
  • 使用 JavaScript 更新输入值到元素

    本文档旨在指导开发者如何使用 JavaScript 将输入框中的值动态更新到页面元素中,并提供代码示例和最佳实践。我们将探讨如何获取输入值、创建和更新元素,以及如何利用表单和本地存储优化用户体验。 动态更新元素内容 在网页开发中,经常需要根据用户的输入动态更新页面上的元素。以下是一个基础示例,演示了…

    2025年12月20日
    000
  • JavaScript深度递归:高效统计复杂嵌套结构中的对象与数组

    本文深入探讨了如何使用JavaScript递归函数统计复杂嵌套数据结构(如主对象中包含其他对象和数组)的总数量。通过分析一个具体的代码示例,我们将重点解析递归调用中count += recursiveCall()模式的工作原理,阐明其在累加各层级统计结果中的关键作用,并解释为何直接调用递归函数而不捕…

    2025年12月20日
    000
  • TypeORM与PostgreSQL中的索引策略:自动创建、显式定义与优化实践

    本教程深入探讨typeorm在postgresql数据库中管理索引的机制。我们将分析typeorm何时自动创建索引(如主键和唯一约束),以及如何使用`@index()`装饰器显式定义单个列或复合索引。文章还将详细比较复合索引与单个索引的适用场景,并提供最佳实践,帮助开发者有效优化数据库查询性能,避免…

    2025年12月20日
    000
  • 在TypeORM中高效使用PostgreSQL索引

    本教程深入探讨了TypeORM与PostgreSQL数据库中索引的创建与管理。文章详细阐述了TypeORM在何种情况下会自动生成索引(如主键和唯一约束),以及在关系型字段上需要手动使用`@Index`装饰器创建索引的重要性。同时,教程还比较了独立索引与复合索引的优劣,并提供了实践建议,帮助开发者根据…

    2025年12月20日
    000
  • 如何用Nuxt.js实现服务端渲染的优化策略?

    启用现代模式、合理使用asyncData与fetch、开启gzip/Brotli压缩、优化关键资源加载、利用缓存策略,可显著提升Nuxt.js应用的SSR性能和首屏加载速度。 在使用 Nuxt.js 构建高性能的 Vue 应用时,服务端渲染(SSR)是提升首屏加载速度和 SEO 效果的关键。要真正发…

    2025年12月20日
    000
  • 使用递归函数统计JavaScript嵌套对象与数组数量的教程

    本文深入探讨如何使用JavaScript递归函数来统计复杂嵌套对象中的对象和数组数量。重点解析递归过程中计数变量的累加机制,特别是count++和count += recursiveCall()的协同作用,帮助读者理解如何有效聚合子树的统计结果,从而处理多层级数据结构。 引言:处理复杂嵌套数据结构的…

    2025年12月20日
    000
  • Django 迁移后出现IntegrityError:列已删除但仍被引用

    在使用Django开发过程中,即使在模型中删除了某个字段并执行了迁移,仍然可能遇到 `IntegrityError`,提示某个已删除的列违反了非空约束。这通常是由于数据库中的状态与Django的模型定义不一致导致的。本文将深入探讨这个问题的原因,并提供详细的解决方案,帮助开发者彻底解决此类问题。 问…

    2025年12月20日
    000
  • TypeScript 中正确引入和使用 RequestInit 类型

    本文旨在解决在 TypeScript 项目中自定义 `fetchServer` 方法时,如何正确引入并使用 `RequestInit` 类型,避免类型定义错误,并提供 ESLint 相关的配置建议,确保代码的正确性和可维护性。通过本文,你将能够掌握在 TypeScript 中使用 `fetch` A…

    2025年12月20日
    000
  • JavaScript模块化开发:解决import语法错误与全局函数引用问题

    本文深入探讨了在javascript模块化开发中常见的两个问题:`import`语句在非模块环境下的`syntaxerror`以及模块内函数无法被html全局调用的`referenceerror`。教程将详细解释这些错误产生的原因,并提供使用` 理解JavaScript模块化与全局作用域 在现代We…

    2025年12月20日
    000
  • 解决 Persistent UTM 代码中添加多余问号的问题

    本文旨在解决在使用 JavaScript 持久化 UTM 参数时,即使 URL 中不存在 UTM 参数,也会错误地向链接添加问号的问题。通过分析问题代码,找出错误根源,并提供修改后的代码示例,确保只有在存在 UTM 参数时才添加参数,避免生成不必要的问号。 在使用 JavaScript 追踪 UTM…

    2025年12月20日
    000
  • 解决自定义Fetch Hook中的无限循环问题

    本文旨在解决在使用自定义React Hook进行API请求时遇到的无限循环问题,重点分析了`useState`的使用以及如何避免因状态更新导致的重复渲染。通过提供修改后的代码示例,帮助开发者构建更稳定、高效的自定义Hook。 在React开发中,自定义Hook是提高代码复用性和可维护性的重要手段。然…

    2025年12月20日
    000
  • 提升 React Web 应用中 Shadow DOM 内容的可访问性

    本文旨在解决 React Web 应用中,当组件内容被封装在 Shadow DOM 内部时,如何提升其可访问性的问题。重点讨论了针对屏幕阅读器和浏览器内置内容阅读器的不同解决方案,包括动态添加标签元素和使用 role=”alert” 属性等方法,旨在帮助开发者确保 Shado…

    2025年12月20日
    000
  • 如何实现一个自动化前端测试流水线?

    实现自动化%ignore_a_1%测试流水线需串联代码提交、测试执行、反馈与部署。1. 选用 Jest/Vitest 做单元测试,React Testing Library/Vue Test Utils 进行组件测试,Playwright 实现 E2E 与视觉回归测试;2. 通过 GitHub Ac…

    2025年12月20日
    000
  • 在 React 中渲染 HTML Partial Response 的正确姿势

    本文旨在解决在 React 应用中渲染从后端获取的 HTML partial response 的问题。不同于常见的 JSON 数据交互,直接接收 HTML 片段并将其渲染到页面上,需要考虑样式隔离和避免潜在的安全风险。本文将探讨使用 iframe 嵌入 HTML 内容的方案,并提供代码示例和注意事…

    好文分享 2025年12月20日
    000
  • JavaScript Canvas图形变换:实现元素的旋转与定位

    本教程详细讲解如何使用javascript canvas的上下文(context)进行图形元素的旋转与定位。通过介绍`ctx.save()`、`ctx.translate()`、`ctx.rotate()`和`ctx.restore()`等核心api,我们将学习如何精确地围绕指定点旋转canvas上…

    2025年12月20日
    000
  • 使用 JavaScript 更新元素中的输入值

    本文档旨在指导开发者如何使用 JavaScript 动态更新 HTML 元素中的输入值,并提供两种实现方法:直接更新和利用表单。此外,还介绍了如何使用 LocalStorage 持久化存储消息,以便在页面刷新后保留数据。 方法一:直接更新元素 这种方法直接获取输入元素的值,并在点击事件发生时,将这些…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信