Я создал базовую c форму в реакции. js, где я могу получить значения после того, как пользователь отправит форму.
Однако, когда я пытаюсь изменить значения с помощью функции handleSubmit
, я не вижу изменений, внесенных в состояние.
Я сделал копию состояния и внес изменения отражаются в скопированном состоянии. Но когда я устанавливаю старое состояние равным обновленному состоянию, изменения не отражаются
Мой код выглядит следующим образом
state = {
name: null,
ContactNumber: null
}
handleChange = (event) => {
this.setState({
[event.target.name] : event.target.value
})
}
handleSubmit = (event) => {
event.preventDefault()
let Copystate = JSON.parse(JSON.stringify(this.state))
Copystate.ContactNumber = 100
console.log(Copystate) // displaying the contact number as 100
this.setState({
state : Copystate
})
console.log(this.state) // displays the number which was submitted in the form
}
render(){
return(
<div>
<h2>Form</h2>
<form onSubmit={this.handleSubmit}>
<div>
<label>Name</label>
<input type="text" name="name" required = {true} onChange = {this.handleChange}/>
<label>Contact Number</label>
<input type="number" name="ContactNumber" required = {true} onChange = {this.handleChange}/>
<button type="submit" label="submit" >Submit</button>
</div>
</form>
</div>
);
}
}
Может кто-нибудь, пожалуйста, сообщите мне, где я иду не так? Спасибо