聊天记录滚动锚定的实现

1. 开始

有个项目需要用到IM聊天功能,在向上翻更多聊天记录时,需要将位置固定,也就是加载更多时不要滚动到顶部,也不要跳动、抖动。

尝试了n种方法,终于可以了,这里记录下。

2. 尝试方案

2.1. overflow-anchor

尝试用css自带属性overflow-anchor: auto解决这一问题,但是它的兼容性太差了,在chrome、开发者工具中调试的效果可以,但是真机小程序、H5都不行。

此外,这一属性需要scrollTop不能为0,也就是在插入数据之前检查下scrollTop,如果为0,则调用API让scroll-view向下滚动一点。

2.2. 赋值前将scrollY设置为false

这种方式是想在list添加前将scroll-view固定,然后在前面插入数据,想法是挺好的,但是一插入数据,scroll-view还是滚动到了顶部,也就是scroll-view内部是让scroll-top在插入数据前后不变。

2.3. 赋值后立即设置scrollTop

这种方式是想在数据插入后立即滚动到原来的位置,H5是没问题的,小程序不可以,因为小程序设置scrollTop是异步的,list一旦赋值,并传递到渲染层就渲染了,这时候再改变scrollTop,或设置scrollInfoView会导致页面抖动。

2.4. 赋值后立即调用scrollInfoView

无效的原因与上相同。

3. 解决方法

3.1. scroll-view倒置

采用的是scroll-view倒置,列表数据也倒置,这样每次加载下一页,可以当成是普通listloadMore,从而解决跳动的问题。

scss 复制代码
.press-message-detail {
  transform: rotate(180deg);

  .press-message-item {
    transform: rotate(180deg);
  }
}

调用者无需关心list的翻转,由组件内部处理:

ts 复制代码
export default {
  computed: {
    reversedList() {
      const res = [
        ...this.list,
      ];
      res.reverse();
      return res;
    },
  },
}

3.2. 隐藏scrollbar

同时要注意隐藏scrollbar,因为scrollbar此时跑到了左边。用下面的方式在小程序中无效,采用的是Dom覆盖的方式。

scss 复制代码
::-webkit-scrollbar {
  display: none;
  width: 0;
  height: 0;
  color: transparent;
}

3.3. 数据少的情况

此外,当聊天内容不足一屏时,消息是堆在下面的,因为scroll-view被倒置了。

解决方案是,设置一个placeholderdom,设置为flex:1,让它和消息内容共享父容器的高度。

4. 体验地址

目前在press-ui示例项目中可以查看效果,三端(H5、微信小程序、QQ小程序)表现一致。

另外,欢迎使用press-ui跨端组件库。

5. 资料

网上被这一问题困扰的人还挺多的,这是我查阅资料时看到的一部分:

  1. developers.weixin.qq.com/community/d...
  2. developers.weixin.qq.com/community/d...
  3. developers.weixin.qq.com/community/d...
  4. developers.weixin.qq.com/community/d...
  5. developers.weixin.qq.com/community/d...
  6. developers.weixin.qq.com/community/d...
相关推荐
AI大模型顾潇1 分钟前
[特殊字符] 本地大模型编程实战(29):用大语言模型LLM查询图数据库NEO4J(2)
前端·数据库·人工智能·语言模型·自然语言处理·prompt·neo4j
九月TTS23 分钟前
TTS-Web-Vue系列:Vue3实现内嵌iframe文档显示功能
前端·javascript·vue.js
爱编程的小学究24 分钟前
【node】如何把包发布到npm上
前端·npm·node.js
weixin_473894771 小时前
前端服务器部署分类总结
前端·网络·性能优化
LuckyLay1 小时前
React百日学习计划-Grok3
前端·学习·react.js
澄江静如练_1 小时前
小程序 存存上下滑动的页面
前端·javascript·vue.js
互联网搬砖老肖1 小时前
Web 架构之会话保持深度解析
前端·架构
菜鸟una2 小时前
【taro3 + vue3 + webpack4】在微信小程序中的请求封装及使用
前端·vue.js·微信小程序·小程序·typescript·taro
hao_04132 小时前
elpis-core: 基于 Koa 实现 web 服务引擎架构设计解析
前端
狂野小青年2 小时前
npm 报错 gyp verb `which` failed Error: not found: python2 解决方案
前端·npm·node.js