Tell us what’s happening:
My code seems to be running fine but I can’t seem to get past challenge 2. The messages says => ’ The DisplayMessages
component should render a div
containing an h2
element, a button
element, a ul
element, and li
elements as children.'<=
but I have done precisely that or is it because I’m missing out something?
I need help.
Your code so far
class DisplayMessages extends React.Component {
constructor(props) {
super(props);
this.state = {
input: '',
messages: []
}
}
// Add handleChange() and submitMessage() methods here
handleChange(event) {
this.setState ({
input: event.target.value,
messages: this.state.messages
});
};
submitMessage() {
this.setState({
input: '',
messages: [...this.state.messages, this.state.input]
});
};
render() {
return (
<div>
<h2>Type in a new Message:</h2>
{ /* Render an input, button, and ul below this line */ }
<input value={this.state.input} onChange={this.handleChange.bind(this)} />
<button onClick={this.submitMessage.bind(this)} >Add message</button>
<div>{this.state.input}</div>
<ul>{this.state.messages.map(item => {
return <li>{item}</li>
})}</ul>
{ /* Change code above this line */ }
</div>
);
}
};
Your browser information:
User Agent is: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/122.0.0.0 Safari/537.36
Challenge Information:
React and Redux - Manage State Locally First