跳到主要内容

TouchableHighlight

提示

如果您正在寻找一种更广泛且面向未来的方式来处理基于触摸的输入,请查看 Pressable API。

一个用于使视图正确响应触摸的包装器。按下时,被包裹视图的不透明度会降低,从而允许底层颜色透出来,使视图变暗或着色。

底层来源于将子组件包裹在一个新的 View 中,这可能会影响布局,如果未正确使用,有时会导致不必要的视觉异常,例如如果被包裹视图的 backgroundColor 没有显式设置为不透明颜色。

TouchableHighlight 必须有一个子组件(不能为零个或多个)。如果您希望有多个子组件,请将它们包裹在一个 View 中。

tsx
function MyComponent(props: MyComponentProps) {
return (
<View {...props} style={{flex: 1, backgroundColor: '#fff'}}>
<Text>My Component</Text>
</View>
);
}

<TouchableHighlight
activeOpacity={0.6}
underlayColor="#DDDDDD"
onPress={() => alert('Pressed!')}>
<MyComponent />
</TouchableHighlight>;

示例


参考

属性

TouchableWithoutFeedback 属性

继承 TouchableWithoutFeedback 属性


activeOpacity

确定当触摸激活时,被包裹视图的不透明度应为多少。值应在 0 到 1 之间。默认为 0.85。需要设置 underlayColor

类型
number

onHideUnderlay

在底层隐藏后立即调用。

类型
function

onShowUnderlay

在底层显示后立即调用。

类型
function

ref

一个 ref 设置器,挂载时将被分配一个 元素节点


style

类型
View.style

underlayColor

当触摸激活时将显示出来的底层颜色。

类型
颜色

hasTVPreferredFocus
iOS

(仅限 Apple TV) 电视首选焦点(请参阅 View 组件的文档)。

类型
bool

nextFocusDown
Android

电视下一个向下焦点(请参阅 View 组件的文档)。

类型
number

nextFocusForward
Android

电视下一个向前焦点(请参阅 View 组件的文档)。

类型
number

nextFocusLeft
Android

电视下一个向左焦点(请参阅 View 组件的文档)。

类型
number

nextFocusRight
Android

电视下一个向右焦点(请参阅 View 组件的文档)。

类型
number

nextFocusUp
Android

电视下一个向上焦点(请参阅 View 组件的文档)。

类型
number

testOnly_pressed

便于快照测试。

类型
bool