解决小程序中ios可以正常滚动,而Android失效题目

打印 上一主题 下一主题

主题 859|帖子 859|积分 2577

解决小程序中 iOS 可以正常滚动,而 Android 失效题目

在开发小程序时,我们经常会遇到一些平台兼容性题目。最近,我在开发一个小程序时遇到了一个题目:在 iOS 设备上可以正常滚动加载更多数据,而在 Android 设备上却无法正常工作。颠末一番调试和研究,我找到了一种可靠的解决方案,联合了 Intersection Observer 和传统的滚动事件监听,确保在所有设备上都能正常工作。
题目形貌

在小程序中,我们需要实现一个列表的无限滚动加载功能。当用户滚动到底部时,自动加载更多数据。在 iOS 设备上,这个功能可以正常工作,但在 Android 设备上,滚动事件无法正常触发,导致无法加载更多数据。
解决方案

为了确保在所有设备上都能正常工作,我们可以联合 Intersection Observer 和传统的滚动事件监听来实现加载更多数据的功能。这样可以确保在某些设备上 Intersection Observer 可能不可靠的情况下,仍然可以通过滚动事件来触发加载更多数据。
实现步调


  • 使用 Intersection Observer 监听滚动到底部: Intersection Observer 是一种现代的 API,可以用来检测元素是否进入视口。我们可以使用它来监听 .loading 元素是否进入视口,从而触发加载更多数据的操作。
  • 使用传统的滚动事件监听: 传统的滚动事件监听可以确保在 Intersection Observer 可能不可靠的情况下,仍然可以通过滚动事件来触发加载更多数据。
  • 联合两种方法: 联合 Intersection Observer 和传统的滚动事件监听,确保在所有设备上都能正常工作。
代码示例

下面是联合两种方法的代码示例:
  1. let observer: IntersectionObserver
  2. const handleScroll = (e: any) => {
  3.   const listElement = e.target
  4.   const scrollTop = listElement.scrollTop
  5.   const clientHeight = listElement.clientHeight
  6.   const scrollHeight = listElement.scrollHeight
  7.   if (scrollTop + clientHeight >= scrollHeight - 10) {
  8.     if (!isLoading.value && !isGetAll.value) {
  9.       console.log('到底了')
  10.       getList() // 接口返回的列表数据,按需添加即可
  11.     }
  12.   }
  13. }
  14. onMounted(() => {
  15.   getList()
  16.   // 使用 Intersection Observer API 监听滚动到底部
  17.   observer = new IntersectionObserver(
  18.     entries => {
  19.       entries.forEach(entry => {
  20.         if (entry.isIntersecting && !isLoading.value && !isGetAll.value) {
  21.           console.log('到底了')
  22.           getList()
  23.         }
  24.       })
  25.     },
  26.     {
  27.       root: document.querySelector('.list'),
  28.       threshold: 1.0,
  29.     },
  30.   )
  31.   const sentinel = document.querySelector('.loading')
  32.   if (sentinel) {
  33.     observer.observe(sentinel)
  34.   }
  35.   // 监听滚动事件,分页加载数据
  36.   const listElement = document.querySelector('.list')
  37.   if (listElement) {
  38.     listElement.addEventListener('scroll', handleScroll)
  39.   }
  40. })
  41. onUnmounted(() => {
  42.   if (observer) {
  43.     observer.disconnect()
  44.   }
  45.   const listElement = document.querySelector('.list')
  46.   if (listElement) {
  47.     listElement.removeEventListener('scroll', handleScroll)
  48.   }
  49. })
复制代码
css
  1. .list {
  2.    padding: 12px 20px 0;
  3.    height: 100vh;
  4.    overflow: auto;
  5.    // 其他标签样式
  6. }
复制代码
 结论
通过联合 Intersection Observer 和传统的滚动事件监听,我们可以确保在所有设备上都能正常工作,而且制止重复加载数据的题目。这种方法不仅解决了 iOS 和 Android 设备之间的兼容性题目,还提高了代码的可靠性和可维护性。
(注意:仅供参考)

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

麻花痒

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表