5

我遇到了一个问题,嵌套的 Touchable 中的双重触摸(同时触摸)会到达父 Touchable。

在下面的示例中,Touchable 嵌套了三层。当我按下最深的可触摸(蓝色)时,控制台会正确打印“蓝色”。当我按下分别打印“绿色”和“红色”的其他图层时,它的行为也正确。

当我同时进行两次触摸和释放时,就会出现奇怪的行为——然后触摸层的 onPress 根本不会被调用。相反,当两个触摸都结束时,父 Touchable 只接收一次触摸。

此外,当我在最外层(没有父可触摸的红色)上同时执行两次触摸时,该层将接收触摸。从我的角度来看,这似乎更正确,但偏离了上述嵌套 Tocuables 中的奇怪行为。

<View style={{flex:1, backgroundColor:"#666666"}}>

    <TouchableHighlight onPress={()=>{console.log("red")}}>
      <View style={{backgroundColor:"#FF0000", height:300}}>   
        <TouchableHighlight onPress={()=>{console.log("green")}}>
          <View style={{backgroundColor:"#00FF00", height:200}}>
            <TouchableHighlight onPress={()=>{console.log("blue")}}>
              <View style={{backgroundColor:"#0000FF", height:100}} />
            </TouchableHighlight>
          </View>
        </TouchableHighlight>
      </View>
    </TouchableHighlight>
</View>
4

1 回答 1

1

我复制了你的代码,我有点不知道它是否真的看起来像你想要实现的东西:https ://snack.expo.io/@zvona/onpressin

Snack不允许使用多次触摸,但我做了一个长镜头:使用onPressIn而不是onPress.

于 2018-04-02T16:56:07.363 回答