728x90
onPress, activeOpacity 등의 값 가질 수 있음
Child 뷰가 클릭될수 있게 돕는 기능으로, activeOpacity ={1}을 주면 클릭할때 반짝거리는 효과 완전 사라지고 평면 클릭하는것처럼 됨.
onPressIn, onPressOut등을 사용하면 버튼을 눌렀을 때, 버튼을 뗐을 때를 인식해서 받아올 수 있음
샘플 예시
import React, { Component } from 'react';
import {
StyleSheet,
Text,
View,
Image,
TextInput,
Button,
Platform,
TouchableOpacity,
TouchableHighlight,
TouchableNativeFeedback,
TouchableWithoutFeedback
} from 'react-native';
import {
createStackNavigator
}from 'react-navigation'
export default class App extends Component {
constructor(){
super();
this.state={
number:0
}
}
notifySomething(){
console.log("Clicked"+this.number)
this.setState({
number:this.state.number+1
});
}
render() {
return (
<View style={styles.container}>
<View style = {styles.container2}>
{itemViews}
</View>
<View style = {styles.container3}>
<TouchableOpacity
onPress={()=>this.notifySomething()}
activeOpacity={1}
>
<View >
<Image style={styles.image1}
source={require('../assets/images/miami.jpg')}>
</Image>
</View>
</TouchableOpacity>
<Text style={styles.text}>
{this.state.number}
</Text>
</View>
</View>
);
}
}
const styles = StyleSheet.create({
container: {
flex: 1,
flexDirection: 'column',
padding: 20,
justifyContent:'center',
alignItems:'center',
backgroundColor:'gray',
},
container2: {
flex: 1,
flexDirection: 'row',
padding: 20,
justifyContent:'center',
alignItems:'center',
backgroundColor:'yellow',
},
container3: {
flex: 1,
flexDirection: 'column',
padding: 20,
justifyContent:'center',
alignItems:'center',
backgroundColor:'white',
},
textContainer:{
height:80,
backgroundColor:"cyan",
marginLeft:5,
justifyContent:'center',
},
text:{
width:30,
textAlign:'center',
backgroundColor:'red',
borderRadius:50,
padding:10
},
image1:{
width:30,
height:60,
backgroundColor:'red',
borderRadius:50,
padding:10
}
});
728x90
'프로그래밍 > React Native(2018)' 카테고리의 다른 글
[React Native] props 예시 (0) | 2019.09.28 |
---|---|
[React Native] Google Maps (0) | 2019.09.28 |
[React Native] Image (0) | 2019.09.28 |
[React Native] Touchable Highlight (0) | 2019.09.28 |
[React Native] Documentation (0) | 2019.09.28 |
댓글