React-native animated.event 自定义 onScroll 监听器

Posted

技术标签:

【中文标题】React-native animated.event 自定义 onScroll 监听器【英文标题】:React-native animated.event custom onScroll listener 【发布时间】:2018-01-14 21:41:58 【问题描述】:

在官方 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
        
      
    ]
  )

你能解释一下怎么做吗?

【问题讨论】:

【参考方案1】:

查看源代码时:

/**
   * 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
    ,
  ,
)

【讨论】:

如何在这里添加一个函数作为监听器?我尝试将它绑定在那里,但它似乎没有触发。对此有何进一步解释?【参考方案2】:

编写处理函数,如:

    handleScroll = (e) => 
        console.log(e.nativeEvent.contentOffset.y);
    

你可以像这样添加listener

    Animated.event(
       [ nativeEvent:  contentOffset:  y: this.state.scrollY   ],
        listener: (event) => this.handleScroll(event) 
    )

【讨论】:

【参考方案3】:

无法让 Michal 的解决方案为我工作。结束了这个

onScroll=( nativeEvent ) => 
               animatedY.setValue(nativeEvent.contentOffset.y);
               // other actions to be performed on scroll
         

【讨论】:

以上是关于React-native animated.event 自定义 onScroll 监听器的主要内容,如果未能解决你的问题,请参考以下文章

在另一个 React-Native 库中使用 React-Native 库

React-Native + crypto:如何在 React-Native 中生成 HMAC?

React-native:如何在 React-native 中使用(和翻译)带有 jsx 的 typescript .tsx 文件?

React-Native 开发 在react-native 中 运用 redux

在解析模块`react-native/Libraries/Core/Devtools/getDevServer`时,发现了Haste包`react-native`

使用 react-native run-android 运行时出现 React-Native 错误