Ich bin neu in ReactJS. Ich habe versucht, gleichzeitig den Text und die Farbe einer Schaltfläche zu ändern, wenn ich darauf klicke. Dieser Code funktioniert:Inline-Stile in ReactJS
class ToggleHelp extends React.Component {
constructor(props) {
super(props);
this.state = {isHelpOn: true};
// This binding is necessary to make `this` work in the callback
this.handleClick = this.handleClick.bind(this);
}
handleClick() {
this.setState(prevState => ({
isHelpOn: !prevState.isHelpOn
}));
}
render() {
return (
<button onClick={this.handleClick}>
{this.state.isHelpOn ? 'HELP ON' : 'HELP OFF'}
</button>
);
}
}
ReactDOM.render(
<ToggleHelp />,
document.getElementById('root')
);
Aber wenn ich versuche, einen Inline-Stil wie die folgenden aplly, Code nicht mehr funktioniert.
<button style={background:yellow} onClick={this.handleClick}>
{this.state.isHelpOn ? 'HELP ON' : 'HELP OFF'}
</button>
Ich habe mehrere Male versucht, es auf verschiedene Arten zu tun. Ich möchte, dass es für den Moment ein Inline-Stil ist. Ist es möglich, Inline-Stile direkt von React anzuwenden? Wenn ja, besteht die Idee darin, den Status auszuwerten und über eine bedingte Anweisung eine Farbe auf eine andere zu setzen.
schreiben Sie es wie folgt aus: 'style = {{Backgroundcolor: 'gelb'}}' –
@MayankShukla noch fehlenden Anführungszeichen –
@MayankShukla ... nicht wirklich ... –