);}export default Playground;
代码解释:
const [form] = Form.useForm();:创建并获取表单控制实例。useEffect(() => { … }, [form]);:在组件首次渲染后执行副作用,这里模拟异步数据获取。[form]作为依赖项,确保在form实例可用时执行。form.setFieldsValue(…):使用此方法设置表单字段的值。moment(response.date):将日期字符串转换为moment对象。moment(response.time, “HH:mm:ss”):将时间字符串转换为moment对象,并明确指定了输入格式为 “HH:mm:ss”。请注意,TimePicker的format属性(例如 “HH:mm”)定义的是组件显示时的格式,而moment函数第二个参数定义的是解析输入字符串时的格式。
注意事项与总结
Ant Design v5+ 的变化:从 Ant Design v5 开始,其日期时间组件的默认日期库已从 moment.js 切换为 dayjs。如果你正在使用或计划升级到 Ant Design v5 及更高版本,你需要将 moment 的相关操作替换为 dayjs。dayjs 的 API 与 moment 非常相似,转换起来相对容易:
import dayjs from "dayjs";// ...form.setFieldsValue({ ...response, date: dayjs(response.date), time: dayjs(response.time, "HH:mm:ss"),});
格式匹配:在将时间字符串转换为moment(或dayjs)对象时,务必确保 moment(timeString, formatString) 中的 formatString 与后端返回的时间字符串的实际格式完全一致。否则,解析可能会失败,导致组件显示为空或不正确的值。异步数据加载:当表单数据来自异步请求时,使用 useEffect 结合 form.setFieldsValue 是设置初始值的标准且推荐的做法。避免直接将异步数据作为 initialValues 属性传递给 Form 组件,因为 initialValues 仅在组件首次渲染时生效,后续数据更新不会自动反映。
通过以上方法,开发者可以有效地处理后端返回的日期和时间字符串,并将其正确地显示在Ant Design的日期和时间选择器组件中,从而提升用户体验和应用的健壮性。
以上就是处理Ant Design中日期和时间字符串的转换与表单初始化的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1516121.html
微信扫一扫
支付宝扫一扫