gpt4 book ai didi

react-admin - 带有 SimpleFormIterator 和条件输入的 ArrayInput

转载 作者:行者123 更新时间:2023-12-04 15:55:49 25 4
gpt4 key购买 nike

假设我的创建表单中有以下数组

    const CreateDefaults = {Inputs: [{id: "ID1", param: "a"},{id: "ID2", param: "b"}]};

然后我想仅在 id==="ID2"

时显示额外的 TextInput
export const MyCreate = withStyles(myStyles)(({ classes, ...props }) => (
<Create {...props}>
<SimpleForm defaultValue={CreateDefaults}>
<ArrayInput source="Inputs" {...props}>
<SimpleFormIterator {...props}>
<DisabledInput source="id" />
{/*this does not work*/}
{this.id === "ID2" ? (<TextInput source="ParamValue"/>) :null}
</SimpleFormIterator>
</ArrayInput>
</SimpleForm>
</Create>
));

我怎样才能做这样的事情?我知道对于整个表单,可以使用 FormDataConsumer。但是,对于每次迭代,在 ArrayInput/SimpleFormIterator 中可以做什么?

如何在迭代中访问当前对象?我试过类似 the answer given to the 'Custom Input do not receive record when inside ArrayInput' issue in the react-admin github page 的东西, 但它仍然没有收到自定义输入中的记录。

最佳答案

来自最新文档here ,你可以看到,如果你使用 ArrayInput 中的 FormDataConsumer,你有一个名为 scopedFormData 的参数,你可以使用它来获取当前记录并取消引用以获取您需要的任何字段。它通常还与 getSource 函数一起使用,您可以在 FormDataConsumer 中设置源时使用。

关于react-admin - 带有 SimpleFormIterator 和条件输入的 ArrayInput,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51741302/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com