React +AntD + From组件重复提交数据(已解决)

开发场景:

react +Hooks +andt

提交form表单内容给数据库(使用antd的form组件)


问题描述

提交是异步的,请提交方式是POST 方式

提交表单内容给后端,却产生了两次提交记录(当然,数据新增了两条数据)。可以理解是重复提交(2次),核心代码如下:




原因分析:

一开始去找解决方案,误以为是没做防抖和节流的缘故,方向错了,问题肯定不好解决,后端也尝试了休眠3秒,有效,但是吧,,,。

因为提交方式是POST ,想到了POST 会发送两次请求(当发送带有自定义请求头的 POST 请求时,浏览器会先发送一个 OPTIONS 请求进行预检,如果服务器允许该请求,则浏览器会再次发送实际的 POST 请求。这就是为什么有时候会看到 POST 请求被发送了两次的情况。),但这也不是原因

最后肯定不理想,还白白浪费了时间,


解决方案:

htmlType="submit"导致的。删除,,

看一下修改之前的:

修改之后的:

会发现少了htmlType="submit" ,(htmlType="submit" 默认情况下,点击后会执行提交form表单的动作。)

那Button 里面还有一个onClick(form.submit),也是表单提交。所以会提交两次,

真的是大意了,

相关推荐
指尖跳动的光14 分钟前
前端如何通过设置失效时间清除本地存储的数据?
前端·javascript
长空任鸟飞_阿康17 分钟前
MasterGo AI 实战教程:10分钟生成网页设计图(附案例演示)
前端·人工智能·ui·ai
GDAL26 分钟前
从零开始上手 Tailwind CSS 教程
前端·css·tailwind
于慨32 分钟前
dayjs处理时区问题、前端时区问题
开发语言·前端·javascript
哀木1 小时前
理清 https 的加密逻辑
前端
拖拉斯旋风1 小时前
深入理解 LangChain 中的 `.pipe()`:构建可组合 AI 应用的核心管道机制
javascript·langchain
肖老师xy1 小时前
Ai生成时间排期进度
javascript·vue.js·elementui
借个火er1 小时前
无界微前端源码解析:路由同步
前端
Aliex_git1 小时前
Vue 错误处理机制源码理解
前端·javascript·vue.js
ejjdhdjdjdjdjjsl1 小时前
Winform初步认识
开发语言·javascript·ecmascript