TouchableOpacity onPress() 不适用于 react-native-modal

Rob*_*rge 6 react-native

我试图让 TouchableOpacity 与 react-native-modal 一起工作。当我按下按钮时,没有任何反应。

这是我的代码,按下按钮时,没有按下动画,也没有出现警报:

<Modal
  isVisible={this.state.modalVisible}
  onBackdropPress={() => this.setState({ modalVisible: false })}
  deviceWidth={Dimensions.get('window').width}
  deviceHeight={Dimensions.get('window').height}
  backdropColor={'rgba(29, 36, 40, 0.5)'}>
  <View style={styles.modal}>
    <Text style={styles.modalTitle}>Test modal</Text>
    <View style={modalButtons}>
      <TouchableOpacity onPress={() => alert('hello!')}><Text style={styles.modalButton}>Test</Text></TouchableOpacity>
      <TouchableOpacity onPress={() => this.setState({ modalVisible: false })}><Text style={styles.modalButton}>Close</Text></TouchableOpacity>
    </View>
  </View>
</Modal>
Run Code Online (Sandbox Code Playgroud)

我从 react-native 导入 TouchableOpacity,而不是 react-native-gesture-handler(一个解决方案提到了这一点;它对我所做的只是防止按钮不可见)。

编辑:我已将范围缩小到按钮周围的视图。当我删除以下样式时,它会起作用:

  modalButtons: {
    flex: 1,
    flexDirection: 'row',
    justifyContent: 'space-between',
    marginBottom: 30,
  },
Run Code Online (Sandbox Code Playgroud)

有没有办法让这个 flex 工作?我希望按钮并排显示。

小智 27

我有同样的问题。检查您TouchableOpacity是从"react-native"模块导入的,而不是从其他任何东西导入的。(我的是在react-native-gesture-handler。)