gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-03 13:25:14 24 4
gpt4 key购买 nike

在官方的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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com