首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ScrollView onScroll事件

ScrollView onScroll事件
EN

Stack Overflow用户
提问于 2017-12-21 17:28:07
回答 1查看 1.9K关注 0票数 0

react-native: 0.50.3

视频:https://youtu.be/Piz30mH4o1s

我想在滚动中隐藏或显示导航栏。当用户向下滚动时,我会更改导航栏的高度和内容的“paddingTop”位置。在那之后,“onScroll”事件会触发几次,即使用户没有滚动。

我该如何处理这件事?

EN

回答 1

Stack Overflow用户

发布于 2017-12-21 19:40:50

我将向您展示一个类似的示例,希望对您有所帮助:我假设您有header组件和mainPage组件。在mainPage中,您可以使用onScroll方法将scrollY值传递给header组件,如下所示:

代码语言:javascript
复制
            onScroll={Animated.event([
          {
            nativeEvent: {
              contentOffset: {
                y:
                this.refs.header === undefined
                  ? 0
                  : this.refs.header.state.scrollY
              }
            }
          }
        ])}

然后在页眉组件中,您可以插入您的scrollY值来更改headerHeight或页眉填充样式,如下所示

代码语言:javascript
复制
    const headerHeight = this.state.scrollY.interpolate({
  inputRange: [0, HEADER_SCROLL_DISTANCE],
  outputRange: [HEADER_MAX_HEIGHT, HEADER_MIN_HEIGHT],
  extrapolate: "clamp"
});

然后你必须像这样改变你的animated.view的样式:

代码语言:javascript
复制
<Animated.View style={[styles.someStyle, {height: headerHeight}]}></Animated.View>

请随时向我提出任何问题。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47921824

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档