加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

reactjs – React-native animated.event自定义onScroll侦听器

发布时间:2020-12-15 09:34:02 所属栏目:百科 来源:网络整理
导读:在官方的react-native文档中,有一节关于Animated.event方法.例如,他们使用以下代码: onScroll={Animated.event( // scrollX = e.nativeEvent.contentOffset.x [{ nativeEvent: { contentOffset: { x: scrollX } } }] )} 我想将正确的值映射到Animated.event
在官方的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
    },},)}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读