2
Ich habe eine reaktive Elternkomponente erstellt und wenn ein Benutzer auf eine der beiden Optionen klickt, wird eine andere Kindkomponente gerendert.aktive Klasse zum ausgewählten Element hinzufügen reagieren
Je nachdem, welche Option ausgewählt wurde, möchte ich eine active
Klasse hinzufügen.
Siehe meinen Code unten.
Ich habe viele Ansätze genommen, aber habe sie für die Frage abgezogen, wie ich es nicht herausfinden konnte.
class Test extends Component {
constructor(props) {
super(props);
this.state = {
currentView: 'one'
};
this.showOne = this.showOne.bind(this);
this.showTwo = this.showTwo.bind(this);
}
showOne() {
this.setState({
currentView: 'one'
});
}
showTwo() {
this.setState({
currentView: 'two'
});
}
render(){
......
<p className="one" onClick={this.showOne}>One</p>
<p className="two" onClick={this.showTwo}>Two</p>
......
}
}
das ist die eine. muchas gracias hombre! :-) –
Als korrekte Antwort markieren;) – Phil
Wenn Sie ES6 Vorlagenliterale verwenden können: '' 'className = {' one $ {this.state.currentView === 'one'? 'active': ''}} '' 'vermeidet die Wiederholung einer" one "-Klasse – Komo