В настоящее время я использую функцию для переключения hasBeenClicked, затем я использую условие, чтобы убедиться, что цвет фона изменяется только тогда, когда hasBeenClicked имеет значение true.Я бы предпочел использовать троичный оператор внутри опоры стиля для обработки логики.
let randomHex = () => {
let letters = '0123456789ABCDEF';
let color = '#';
for (let i = 0; i < 6; i++) {
color += letters[Math.floor(Math.random() * 16)];
// console.log('here is your random hex color', color);
}
return color;
}
export default class App extends Component {
constructor() {
super()
this.state = {
hasBeenClicked: false
}
}
changeColor = () => {
this.setState({
hasBeenClicked: !this.state.hasBeenClicked
})
if (this.state.hasBeenClicked === true) {
this.setState({
backgroundColor: randomHex()
})
}
}
render() {
return (
<View style={[styles.container, { backgroundColor: this.state.backgroundColor }]}>
<TouchableOpacity
onPress={this.changeColor}
>
<Text style={styles.welcome}>
Welcome to React Native!
</Text>
</TouchableOpacity>
</View>
);
}
}
Я пытался
<View style={[styles.container, { backgroundColor: {this.state.hasBeenClicked: this.state.backgroundColor ? 'green'} }]}>
Какой лучший / правильный способ сделать это?