admin管理员组文章数量:1387380
I have a React Form ponent that receives a state object. The Form contains a couple of Form.Item ponents, one antd Input & one antd Checkbox. I have the following code in my Form ponent:
const RecordsForm = ({ selectedRecord, recordComponentForm }) => {
useEffect(() => {
debugger;
recordComponentForm.setFieldsValue({
Title: selectedRecord ? selectedRecord.Title : null,
IsCurrentRecord: selectedRecord ? selectedRecord.IsCurrentRecord : true,
});
}, [recordComponentForm, selectedRecord]);
return (
<Form
name="seasonForm"
autoComplete="off"
layout={"inline"}
form={recordComponentForm}
>
<Form.Item
label="Title"
name="Title"
rules={[{ required: true, message: "Add a Title" }]}
>
<Input
name="Title"
placeholder="Season Title"
/>
</Form.Item>
<Form.Item
label="Is Active Record"
name="IsCurrentRecord"
valuePropName="checked"
>
<Checkbox name="IsCurrentRecord" />
</Form.Item>
</Form>
);
};
export default RecordsForm;
where the supplied prop recordComponentForm
is instantiated in the parent ponent: const [recordComponentForm] = Form.useForm();
When I run the application and force this ponent to reload with a new selectedRecord
, I want the Form.Item
Input value to change to the Title
from the object and the Checkbox
to reflect the IsCurrentRecord
boolean value of the object. The object passed in looks like this:
The Title Input value changes to show the Title of the object, however the checkbox remains unchanged:
I would like the checkbox to change it's checked
value depending on what es in on the selectedRecord.IsCurrentRecord
object in the same way the Title does. Any advice would be greatly appreciated.
I have a React Form ponent that receives a state object. The Form contains a couple of Form.Item ponents, one antd Input & one antd Checkbox. I have the following code in my Form ponent:
const RecordsForm = ({ selectedRecord, recordComponentForm }) => {
useEffect(() => {
debugger;
recordComponentForm.setFieldsValue({
Title: selectedRecord ? selectedRecord.Title : null,
IsCurrentRecord: selectedRecord ? selectedRecord.IsCurrentRecord : true,
});
}, [recordComponentForm, selectedRecord]);
return (
<Form
name="seasonForm"
autoComplete="off"
layout={"inline"}
form={recordComponentForm}
>
<Form.Item
label="Title"
name="Title"
rules={[{ required: true, message: "Add a Title" }]}
>
<Input
name="Title"
placeholder="Season Title"
/>
</Form.Item>
<Form.Item
label="Is Active Record"
name="IsCurrentRecord"
valuePropName="checked"
>
<Checkbox name="IsCurrentRecord" />
</Form.Item>
</Form>
);
};
export default RecordsForm;
where the supplied prop recordComponentForm
is instantiated in the parent ponent: const [recordComponentForm] = Form.useForm();
When I run the application and force this ponent to reload with a new selectedRecord
, I want the Form.Item
Input value to change to the Title
from the object and the Checkbox
to reflect the IsCurrentRecord
boolean value of the object. The object passed in looks like this:
The Title Input value changes to show the Title of the object, however the checkbox remains unchanged:
I would like the checkbox to change it's checked
value depending on what es in on the selectedRecord.IsCurrentRecord
object in the same way the Title does. Any advice would be greatly appreciated.
3 Answers
Reset to default 5Maybe.. just simply remove name
from Checkbox.
<Form.Item
label="Is Active Record"
name="IsCurrentRecord"
valuePropName="checked"
>
<Checkbox />
</Form.Item>
Checkbox usually return a value of choices (not boolean), so you perhaps should use Switch ponent instead.
But by using valuePropName="checked"
, we could get boolean from Checkbox.
This was simply a case of the Form.Items
sharing the same name and the child ponent it contains. Once I renamed the Form.Item
for the Checkbox to something like IsCurrentRecord_FI
and referred to it as such, it started working.
You can use
<Checkbox name="IsCurrentRecord" checked={Form.useWatch("IsCurrentRecord", form)} />
本文标签:
版权声明:本文标题:javascript - ant design - Update checked value of a checkbox inside a Form.Item using Form.setFieldsValue - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1744562847a2612868.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论