如何在React-Admin V4中设置USESTATE上的输入值?
我正在反应admin v4中移动。 在我的v3(3.19.11)中,我有一个文本输入,其初始值等于状态。 默认情况下,此状态是一个空字符串,当我完成其他一些字段时,它已更新,并且文本输入的值也是如此。
在V4中,InitialValue不再存在,被DefaultValue替换,但似乎并没有以相同的方式工作。 我想知道是否有一种简单的方法可以做与V3相同的事情,而无需使用useform/usecontroller创建自定义表单。
我试图用文本输入,文本字段和本机输入来做到这一点。 我的问题是,我没有更新输入值,或者已更新,但输入未以表格提交。
我的V3中的代码示例:
const [channelName, setChannelName] = useState<string>('');
const [partnerName, setPartnerName] = useState<string>('');
const [campaignName, setCampaignName] = useState<string>('');
useEffect(() => {
const fillCampaignName = () => {
const campaignValues: string[] = [];
campaignValues.push(channelName, partnerName);
const campaignValuesString = campaignValues
.filter((item) => item !== '')
.join('_');
setCampaignName(campaignValuesString);
};
fillCampaignName();
}, [channelName, partnerName]);
<Create {...props}>
<SimpleForm>
<AutocompleteInput variant="standard" source="channel" choices={channels} onChange={(channel: string) => setChannelName(channel)} />
<AutocompleteInput variant="standard" source="partner" choices={partners} onChange={(partner: string) => setPartnerName(partner)} />
<TextInput disabled source="name" variant="standard" label="Campaign name" initialValue={campaignName} />
</SimpleForm>
</Create>
感谢您的帮助。
I'm moving in react-admin v4.
In my v3 (3.19.11), I have a TextInput with an initialValue equals to state.
By default this state is an empty string and when I complete some other fields, it's updated and the value of the TextInput too.
In v4 initialValue doesn't exist anymore and is replaced by defaultValue but it seems that doesn't work the same way.
I would like to know if there is a simple way to do the same thing than v3 without to create a custom form with useForm/useController.
I tried to do that with a TextInput, a TextField and a native input.
My issue is that either I don't have the input value updated, or it's updated but the input is not submitted in the form.
Code example in my v3 :
const [channelName, setChannelName] = useState<string>('');
const [partnerName, setPartnerName] = useState<string>('');
const [campaignName, setCampaignName] = useState<string>('');
useEffect(() => {
const fillCampaignName = () => {
const campaignValues: string[] = [];
campaignValues.push(channelName, partnerName);
const campaignValuesString = campaignValues
.filter((item) => item !== '')
.join('_');
setCampaignName(campaignValuesString);
};
fillCampaignName();
}, [channelName, partnerName]);
<Create {...props}>
<SimpleForm>
<AutocompleteInput variant="standard" source="channel" choices={channels} onChange={(channel: string) => setChannelName(channel)} />
<AutocompleteInput variant="standard" source="partner" choices={partners} onChange={(partner: string) => setPartnerName(partner)} />
<TextInput disabled source="name" variant="standard" label="Campaign name" initialValue={campaignName} />
</SimpleForm>
</Create>
Thanks for your help.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
您是否尝试过使用
DefaultValue
而不是initialValue
?https://marmelab.com/react-act-admin/upgrade.html-upgrade.html#inputs
Have you tried using
defaultValue
instead ofinitialValue
?https://marmelab.com/react-admin/Upgrade.html#inputs
使用UseFormContext,然后您可以通过编程设置设置Value。
Use useFormContext then you can setValue programatically.