以下是创建一个实例
下面是我的组件代码片段:
我正在构建一些绝对定位的卡片,它们彼此相互重叠。这些卡片可以使用
现在,我可以检测到点击事件,但每当用户点击时,我希望禁用
我知道
panResponder
的代码片段: 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(),
};
}
下面是我的组件代码片段:
<Animated.View
key={ item.id }
style={ [ this.getCardStyle(), styles.cardStyle ] }
{ ...this.panResponder.panHandlers }
>
<Card
shouldPanRespond={ this.shouldPanRespond }
item={ item }
/>
</Animated.View>
卡片组件的代码片段:
<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
,以便卡片无法滑动,用户可以滚动内容。一旦用户滚动到底部,我想重新启用滑动,即我想启用 pan。我知道
onStartShouldSetResponder: () => false
可以禁用 panResponder
,但如何在创建实例后禁用它呢?我在其他地方找不到太多相关信息。