Rah*_*are 5 jsx reactjs semantic-ui-react
我正在尝试使用状态来隐藏语义 UI 模型表单,并将 JSON 传递给 Customer 类以添加新客户。我能够传递该值,但最终只有一个值。
当我开始输入名称时,在控制台面板中,第一个字符名称为空“”,第二个字符上有单个“a”

当我单击“创建”按钮时,名称为空“”并且地址具有值。
import React from 'react';
import { Button, Form, Modal } from 'semantic-ui-react';
export default class AddCustomer extends React.Component {
constructor(props) {
super(props);
this.state = {
showCreateForm:false,
formData:{
name: '',
address: ''
}
}
this.handleChangeName = this.handleChangeName.bind(this);
this.handleChangeAddress = this.handleChangeAddress.bind(this);
this.handleSubmit = this.handleSubmit.bind(this);
}
handleChangeName(event) {
const value = event.target.value;
console.log(value);
this.setState({formData:{name:value}});
//when i go to add input the formData is still empty name is empty.
//name: ""
//address: ""
console.log(this.state.formData);
}
handleChangeAddress(event) {
const value = event.target.value;
console.log(value);
this.setState({formData:{address:value}});
//name: "ram" but now there is no address in formData
console.log(this.state.formData);
}
handleSubmit(event) {
event.preventDefault();
////address: "aaaaa" now there no name in formData
console.log(this.state.formData);
this.setState({formData:{
name:this.state.name, address:this.state.address
}});
this.props.onAddFormSubmit(this.state.formData);
}
//On cancel button click close Create user form
closeCreateForm = () => {
this.setState({ showCreateForm: false })
}
//Open Create new Customer form
openCreateCustomer = () => {
this.setState({ showCreateForm: true })
}
render() {
return (
<div>
<Modal closeOnTriggerMouseLeave={false} trigger={
<Button color='blue' onClick={this.openCreateCustomer}>
New Customer
</Button>
} open={this.state.showCreateForm}>
<Modal.Header>
Create customer
</Modal.Header>
<Modal.Content>
<Form onSubmit={this.handleSubmit}>
<Form.Field>
<label>Name</label>
<input type="text" placeholder ='Name' name = "name"
value = {this.state.name}
onChange = {this.handleChangeName}/>
</Form.Field>
<Form.Field>
<label>Address</label>
<input type="text" placeholder ='Address' name = "address"
value = {this.state.address}
onChange = {this.handleChangeAddress}/>
</Form.Field>
<br/>
<Button type='submit' floated='right' color='green'>Create</Button>
<Button floated='right' onClick={this.closeCreateForm} color='black'>Cancel</Button>
<br/>
</Form>
</Modal.Content>
</Modal>
</div>
)
}
}
Run Code Online (Sandbox Code Playgroud)
通过这些行,您可以将整个状态替换为一个字段的值:
你的初始状态:
state = {
formData: {
name: "",
address: ""
}
}
Run Code Online (Sandbox Code Playgroud)
此行之后您的状态:
this.setState({formData:{address:value}});
state = {
formData: {
address: ""
}
}
Run Code Online (Sandbox Code Playgroud)
并用这一行:
this.setState({formData:{name:value}});
state = {
formData: {
name: ""
}
}
Run Code Online (Sandbox Code Playgroud)
正如 Greg b 的回答中提到的,您必须更改特定键的值并按原样复制其余部分。您还可以使用扩展运算符轻松复制其余未修改的字段。
this.setState({...this.state.formData, address: value})
Run Code Online (Sandbox Code Playgroud)
只会更改地址并按原样复制状态的其余部分。当您所在州有多个字段时,这会很方便。
小智 4
这就是你的状态
formData:{
name: '',
address: ''
}
Run Code Online (Sandbox Code Playgroud)
分别更改这两行
this.setState({formData:{address:value}});
this.setState({formData:{name:value}});
Run Code Online (Sandbox Code Playgroud)
到
this.setState({formData:{name: this.state.formData.name, address:value}});`
this.setState({formData:{name:value, address: this.state.formData.address}});`
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
20029 次 |
| 最近记录: |