• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

javascript - react 原生 : How to disable PanResponder temporarily?

[复制链接]
菜鸟教程小白 发表于 2022-12-11 19:37:05 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

以下是创建 panResponder 实例的 fragment :

  constructor( props ) {
    super( props );

    this.position = new Animated.ValueXY();

    this.panResponder = PanResponder.create( {
      onStartShouldSetPanResponder: ( ) => true,
      onPanResponderMove: ( event, gesture ) => {
        this.position.setValue( { x: 0, y: gesture.dy } );
      },
      onPanResponderRelease: ( event, gesture ) => {
        if ( gesture.dy > SWIPE_THRESHOLD ) {
          this.forceSwipe( 'up' );
        } else if ( gesture.dy < -SWIPE_THRESHOLD ) {
          this.forceSwipe( 'down' );
        } else {
          this.resetPosition();
        }
      },
      onMoveShouldSetPanResponderCapture: ( evt, gestureState ) =>
      gestureState.dx !== 0 && gestureState.dy !== 0,
    } );
  }

  getCardStyle() {
    return {
      ...this.position.getLayout(),
    };
  }

以下是我的组件的代码 fragment :

<Animated.View
   key={ item.id }
   style={ [ this.getCardStyle(), styles.cardStyle ] }
   { ...this.panResponder.panHandlers }
>
  <Card
    shouldPanRespond={ this.shouldPanRespond }
     item={ item }
  />
</Animated.View>

卡片组件的代码 fragment :

  <TouchableOpacity
    activeOpacity={ 1 }
    style={ cardStyle }
    onPress={ this.onPress }
  >
    <ScrollView contentContainerStyle={ cardStyle }>
      <Image
        resizeMode="cover"
        style={ imageStyle }
        source={ { uri: img_url } }
      />

      <View style={ titleWrapStyle }>
        <Text style={ textStyle }>{ title }</Text>
      </View>
    </ScrollView>
  </TouchableOpacity>

我正在构建绝对排在另一张之后的卡片。然后可以使用 panResponder 向上或向下滑动这些卡片。但是,在点击屏幕时,我应该在同一屏幕上显示详细信息页面。

现在,我可以检测到点击,但是每当用户点击/点击时,我想禁用 panResponder 以便无法刷卡并且用户可以滚动浏览内容。一旦用户滚动到最后,我想重新启用滑动,即我想启用平移。

我知道 onStartShouldSetResponder: () => false 禁用 panResponder 但我们如何在创建实例后禁用它。我在其他地方找不到太多关于它的信息。



Best Answer-推荐答案


对于将要寻找如何暂时禁用 PanResponder 的人,以下是我的解决方案。

就像@RaHuL - House Javascript 注意到的那样,另一个答案并没有真正解决问题,因为将 onStartShouldSetResponder 设置为与某个可能从 true 变为 false 的状态值相对应的值不会影响 PanResponder (至少看起来是这样)如果它是用 true 创建的。

我通过更改 onPanResponderMove 函数解决了类似的问题。我在状态中有一个值:panResponderEnabled,我的函数如下所示:

 onPanResponderMove: ( event, gesture ) => {
    if(this.state.panResponderEnabled){
       this.position.setValue( { x: 0, y: gesture.dy } ); 
    }
}

当我不想从 PanRespoder 读取更改时,我只需将 panResponderEnabled 设置为 false。

关于javascript - react 原生 : How to disable PanResponder temporarily?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43776755/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap