TouchableHighlight
A wrapper for making views respond properly to touches. On press down, the opacity of the wrapped view is decreased, which allows the underlay color to show through, darkening or tinting the view.
The underlay comes from wrapping the child in a new View, which can affect layout, and sometimes cause unwanted visual artifacts if not used correctly, for example if the backgroundColor of the wrapped view isn't explicitly set to an opaque color.
TouchableHighlight must have one child (not zero or more than one). If you wish to have several child components, wrap them in a View.
-Example:
-renderButton: function() {
+function MyComponent(props) {
return (
- <TouchableHighlight onPress={this._onPressButton}>
- <Image
- style={styles.button}
- source={require('./myButton.png')}
- />
- </TouchableHighlight>
+ <View {...props} style={{flex: 1, backgroundColor: '#fff'}}>
+ <Text>My Component</Text>
+ </View>
);
-},
+}
+
+<TouchableHighlight
+ activeOpacity={0.6}
+ underlayColor="#DDDDDD"
+ onPress={() => alert('Pressed!')}>
+ <MyComponent />
+</TouchableHighlight>
Example
-Props
@@ -168,7 +233,6 @@styleunderlayColorhasTVPreferredFocustvParallaxPropertiesnextFocusDownnextFocusForwardnextFocusLeft-
tvParallaxProperties
-(Apple TV only) Object with properties to control Apple TV parallax effects.
-enabled: If true, parallax effects are enabled. Defaults to true. shiftDistanceX: Defaults to 2.0. shiftDistanceY: Defaults to 2.0. tiltAngle: Defaults to 0.05. magnification: Defaults to 1.0. pressMagnification: Defaults to 1.0. pressDuration: Defaults to 0.3. pressDelay: Defaults to 0.0.
-| Type | Required | Platform |
|---|---|---|
| object | No | iOS |
nextFocusDown
TV next focus down (see documentation for the View component).
| bool | No |