【发布时间】:2018-01-25 12:57:56
【问题描述】:
我的 react native 应用中有 3 个按钮。当用户单击按钮 1 时,我需要将其颜色更改为橙色。但其他按钮应具有默认颜色(灰色)。如果用户下次单击按钮 3,颜色应变为橙色,但第一个按钮颜色应重置为默认值。我对原生反应完全陌生,这就是我尝试过的。但它适用于所有按钮。我知道如果我可以拥有多个具有唯一 Id 的状态,则可以完成。但是我不知道方法。
<Text style={ styles.switchButtonsTitle }>Choose Type of User</Text>
<TouchableOpacity onPress={(userType) =>
this.selectionOnPress("BASIC")} >
<Text style={_style}>
<Text style={styles.switchButtonsText}>BASIC</Text>
</Text>
</TouchableOpacity>
<TouchableOpacity onPress={(userType) =>
this.selectionOnPress("INTERMEDIATE")}>
<Text style={_style}>
<Text style={styles.switchButtonsText}>INTERMEDIATE</Text>
</Text>
</TouchableOpacity>
<TouchableOpacity onPress={(userType) =>
this.selectionOnPress("ADVANCED")}>
<Text style={{backgroundColor: this.state.backgroundColor}}>
<Text style={styles.switchButtonsText}>ADVANCED</Text>
</Text>
</TouchableOpacity>
selectionOnPress
selectionOnPress(userType) {
this.setState({
onClicked: true
});
}
道具
constructor(props) {
super(props);
this.state = {
onClicked: false
}
this.selectionOnPress = this.selectionOnPress.bind(this)
}
渲染(不添加所有代码,只添加对本帖有用的代码)
render() {
var _style;
if (this.state.onClicked) { // clicked button style
_style = {
backgroundColor: "red"
}
}
else { // default button style
_style = {
backgroundColor: "blue"
}
}
【问题讨论】: