reactjs - React-nativeanimate.event 自定义 onScroll 监听器

标签 reactjs react-native ecmascript-6 destructuring

在官方的react-native文档中有一个关于Animated.event方法的部分。例如,他们使用以下代码:

onScroll={Animated.event(
   // scrollX = e.nativeEvent.contentOffset.x
   [{ nativeEvent: {
        contentOffset: {
          x: scrollX
        }
      }
    }]
 )}

我想将正确的值映射到 Animated.event 方法,并且我还想将 onScroll 回调参数映射到我自己的回调。基本上我想做这样的事情:

onScroll={(event) => {
  myOwnCallback(event.nativeEvent.contentOffset.x)
  Animated.event(
    // scrollX = e.nativeEvent.contentOffset.x
    [{nativeEvent: {
        contentOffset: {
          x: scrollX
        }
      }
    }]
  )
}}

您能解释一下如何做到这一点吗?

最佳答案

当你查看源代码时:

/**
   * Takes an array of mappings and extracts values from each arg accordingly,
   * then calls `setValue` on the mapped outputs.  e.g.
   *
   *```javascript
   *  onScroll={Animated.event(
   *    [{nativeEvent: {contentOffset: {x: this._scrollX}}}]
   *    {listener},          // Optional async listener
   *  )
   *  ...
   *  onPanResponderMove: Animated.event([
   *    null,                // raw event arg ignored
   *    {dx: this._panX},    // gestureState arg
   *  ]),
   *```
   *
   * Config is an object that may have the following options:
   *
   *   - `listener`: Optional async listener.
   *   - `useNativeDriver`: Uses the native driver when true. Default false.
   */
  event,

这就是我让它工作的方式:

onScroll={Animated.event(
            [{ nativeEvent: { contentOffset: { y: this.state.scrollY } } }],
  {
    useNativeDriver: true,
    listener: event => {
      const offsetY = event.nativeEvent.contentOffset.y
      // do something special
    },
  },
)}

关于reactjs - React-nativeanimate.event 自定义 onScroll 监听器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45549355/

相关文章:

javascript - 如何在 ReactJS 中查询字段值?

react-native - 在 chrome 调试器中悬停时出现错误? (v79.0.3945.79)

reactjs - 2 ip in 1请求与docker/kubernetes上的axio

reactjs - Redux:我应该在卸载时清除状态

javascript - 如何在react-native中导出所有项目的const

javascript - 通过 Props 将值从 React Stateless Child 传递给 Parent

javascript - 使用 ES6 语法在 .map() 中添加条件检查时出错

typescript - 以 es5 为目标时,如何将 Promises 与 TypeScript 结合使用?

reactjs - Redux 路由器未捕获类型错误 : createHistory is not a function

react-native - Linking.openURL ('tel:xxxxx' )在 React Native iOS 0.72 iOS 中不起作用