Android 上支持 React Native 的 onScroll、onScrollEndDrag、onScrollBeginDrag 吗?

2024-02-26

我有几个简单的console.log中的陈述onScrollBeginDrag, onScroll, and onScrollEndDrag附于一个ScrollView。我可以看到它们在我的 iOS 设备上按预期工作,但在 Android 模拟器上却无法工作。

这就提出了一个问题,这些 props 仅在 iOS 上支持还是 Android 模拟器有问题?

代码很简单:

onScroll={() => console.log("scroll")}
onScrollBeginDrag={() => console.log("begin")}
onScrollEndDrag={() => console.log("end")}

是的,他们受到支持,但他们有问题......

我假设你使用<FlatList />渲染你的组件,对吗?

如果是这样,您的问题很可能是由<View />包含你的<FlatList /> items 被 Android 优化掉。 Android 会自动删除实际上不呈现任何内容的“包装”视图,例如背景颜色或边框。这种优化有助于减少视图层次结构的深度,但在某些情况下可能会导致意外结果(例如这样)...

我添加了一个透明的backgroundColor到包装<View />的项目,现在onScrollBeginDrag, onScrollEndDrag and onScroll的事件<FlatList />正在按预期发射!

<FlatList
  onScrollBeginDrag={() => console.log('begin')}
  onScrollEndDrag={() => console.log('end')}
  onScroll={() => console.log('end')}
  data={[{key: 'a'}, {key: 'b'}]}

  renderItem={({ item }) => (
    <View style={{ backgroundColor: 'transparent' }}>
      <Text>{item.key}</Text>
    </View>
  )}
/>

我还删除了 FlatList 填充,并在包装​​视图中添加了一些填充,这使得可触摸区域更大。

PS:点赞巴托·卡鲁扎 https://github.com/facebook/react-native/issues/22251#issuecomment-438524264.

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Android 上支持 React Native 的 onScroll、onScrollEndDrag、onScrollBeginDrag 吗? 的相关文章

随机推荐

  • 在自定义转场转换期间,视图的导航栏项目错位

    我有一个自定义 Segue 它使用 UIViewAnimationOptionTransitionFlipFromLeft 在视图之间进行转换 当新视图出现在屏幕上时 由于导航栏元素从左对齐状态跳转到适当的位置 会出现短暂但明显的 闪烁 以
  • Windows Phone 7 WebBrowser 控件吞下操作事件?

    如果我将 WebBrowser 控件放置在任何页面上 该页面将不再响应 WebBrowser 下的操作事件 页面的其他区域工作正常 通过覆盖很容易确认OnManipulationCompleted在页面中 然后将 WebBrowser 控件
  • 用C#解析并执行JS

    我有一个简单的爬虫 可以爬行和搜索页面 但现在我遇到了如何执行和解析该页面的 js 链接的问题 有谁知道如何解析和执行js页面吗 example some url 很容易用 webhtmltoolktit 解析 JAVASCRIPT run
  • OCR 解决方案可以检测数字手写体吗?

    有没有一种解决方案可以很好地书写数字 1 10 我尝试了超正方体 但我只得到垃圾 理想情况下是 OSS 但商业也可以 OpenCV 现在附带手写数字识别 OCR 示例 你可以参考一下 http code opencv org project
  • iPhone核心数据“自动轻量级迁移”

    我正在尝试更新一个实现核心数据存储的应用程序 我正在向其中一个实体添加属性 我将以下代码添加到我的委托类中 NSPersistentStoreCoordinator persistentStoreCoordinator if persist
  • 不用Gforth 就可以编译Gforth 吗?

    当我尝试编译 Gforth 0 7 0 时 出现以下错误 configure make compiling Undefined symbols main referenced from start in crt1 10 6 o ld sym
  • 使用 Monit 监控 Laravel 队列工作线程

    我目前正在考虑从 Supervisor 迁移到 Monit 以监视 Laravel 队列工作人员 主要原因是能够监视 CPU 内存和设置电子邮件警报 据主管说 我必须安装另一个软件包 因为我希望尽快监视其他内容 例如 Redis 或许还有
  • 我的 java 线程占用了多少内存?

    有没有办法找出我的java线程在VM中占用了多少内存 例如 使用堆栈跟踪转储或其他一些方法 Thanks Java 线程使用堆作为共享内存 各个线程都有自己的堆栈 您可以通过 Xss命令行选项 默认为 512KB 但所有其他内存 堆 不属于
  • Symfony 数据库教程代码错误

    我已经成功安装和设置了 Symfony 2 并且一直在遵循文档 我目前正在做http symfony com doc 2 0 book doctrine html http symfony com doc 2 0 book doctrine
  • 跟踪 C++ 内存分配

    我正在寻找一种方法来跟踪 C 程序中的内存分配 我是not对内存泄漏感兴趣 这似乎是大多数工具试图找到的 而是为应用程序创建内存使用情况配置文件 理想的输出是函数名称的大列表加上随时间变化的最大分配字节数 或者更好的是随时间变化的堆的图形表
  • ASP.NET Core 3.0 策略重定向

    我们有这部分代码来控制一些服务高级页面 对于没有高级会员资格的用户 拒绝 方法会重定向到升级页面 该代码在asp NET core 2上运行完美 但在asp NET core 3上失败 context Resource 不再是 Author
  • 多个特定于目标的变量值

    按照文档管理特定于目标的变量值 https www gnu org software make manual html node Target 002dspecific html prog CFLAGS g prog prog o foo
  • 如何在 Flutter 应用中播放 .mp3 文件?

    我写了一个Dart从服务器检索 mp3 文件并播放它们的 Web 应用程序 我正在尝试使用 Flutter 编写移动版本 我知道dart web audio是 Web 应用程序的主要选项 但 Flutter 在我的 SDK 中找不到它 我知
  • 使用 jQuery 在“Enter”上提交表单?

    我有一个 bog 标准登录表单 使用 HTML jQuery 的 AIR 项目上的一个电子邮件文本字段 一个密码字段和一个提交按钮 当我在表单上按 Enter 时 整个表单的内容消失 但表单未提交 有谁知道这是否是 Webkit 问题 Ad
  • 带有结构体参数的 C 函数原型

    我想为一个函数编写一个函数原型 其参数是指向结构体的指针 int mult struct Numbers n 但是 结构 Numbers 定义为 struct Numbers int a int b int c 尚未定义 我应该如何为 mu
  • 什么负责生成默认构造函数?

    如果每个班级都有一个默认构造函数那么谁生成它 编译器还是 JVM 简而言之 编译器将在必要时生成默认构造函数 这绝对是由 Java 到字节码编译器完成的 您可以通过检查适当的 class文件使用javap 您应该看到已插入的构造函数 不过我
  • 证书错误:主机名不匹配

    我正在使用代理 位于公司防火墙后面 来登录 https 域 SSL 握手似乎进展不顺利 CertificateError hostname ats finra org 443 doesn t match ats finra org 我正在使
  • 如何处理 Agda 不确定是否在 with 语句中生成构造函数的情况?

    我有以下代码 open import Data Nat open import Agda Builtin Char open import Data Maybe digit Maybe digit n with compare n prim
  • 如何通过 Apache HTTP 服务器让 Vaadin Push 工作?

    我正在尝试让 Vaadin 7 1 5 Push 在 Apache Tomcat 7 0 42 Apache HTTP 服务器 带有 mod proxy wstunnel 的 2 2 14 上工作 当我直接访问 Tomcat 时 即 使用
  • Android 上支持 React Native 的 onScroll、onScrollEndDrag、onScrollBeginDrag 吗?

    我有几个简单的console log中的陈述onScrollBeginDrag onScroll and onScrollEndDrag附于一个ScrollView 我可以看到它们在我的 iOS 设备上按预期工作 但在 Android 模拟