利用ajax提交form表单数据

本文总结了在使用Thymeleaf和adminLTE模板的HTML页面中,通过Ajax提交form表单数据的经验。对于get方式,表单数据通过serialize()序列化直接传递,后端能解析成User对象。而对于post方式,数据需放入请求体,需用@RequestBody User接收,但jQuery默认不直接转换为json。文中列举了手动拼装、扩展jQuery和使用serializeJSON()三种方法,推荐使用serializeJSON()配合json.stringify(),因这种方式简洁高效。
摘要由CSDN通过智能技术生成

利用thymeleaf引擎创建的html中,使用了adminLTE模板,ajax提交form表单数据,本以为很容易实现,却遇到了很多问题,这里进行总结。

1.get方式提交

通过serialize()序列化出来的是userId=11&userName=11这样格式的字符串对象,data参数直接传递就可以,后端方法的参数是User user,是可以进行解析并拼装成user对象的

var allData = $("#userForm").serialize();
console.log(allData);
$.ajax({
            type:"get",
            url:"/system/saveUser.action",
            contentType:'application/json;charset=UTF-8',
            dataType:"json",
            traditional:true,
            data:allData,
            async:true,
            success:function(data) {
                alert(data);
            }
        });

2.post方式提交

与get方式的区别是:把表单的信息放到了请求体中提交,所以后端要用@RequestBody User user去进行解析接收,但是此注解必须是要求json格式的字符串,注意:1.json格式  2.字符串

jQuery默认的方法是没有直接转化为json格式的方法的,所以有三种方式

  2.1

  • 1
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: 在原生ajax中,可以通过以下步骤来提交form表单数据进行post请求。首先,获取form表单元素并将其转换为formData表单对象。然后,创建一个XMLHttpRequest对象,并配置它的请求方式和URL。如果需要发送跨域请求并携带cookie信息,可以设置xhr的withCredentials属性为true。接下来,发送请求并传递formData作为请求参数。最后,监听服务器端给予的响应内容,可以通过xhr的onload事件来获取响应数据。\[1\] 在jQuery中,可以通过以下步骤来提交form表单数据进行post请求。首先,获取form表单元素并将其赋给一个变量。然后,使用$.ajax方法发送post请求,配置请求的类型、URL和数据。如果需要处理formData类型的数据,可以设置processData和contentType属性为false。最后,可以在success回调函数中处理服务器端返回的响应数据,或在error回调函数中处理请求失败的情况。\[2\] 需要注意的是,无论是原生ajax还是jQuery,如果要模拟form表单提交数据,需要在发送请求前设置请求头的Content-Type为"application/x-www-form-urlencoded",并将表单中的数据以键对的形式拼接成字符串,并作为send函数的参数发送。\[3\] #### 引用[.reference_title] - *1* *2* [通过ajax提交form表单数据的几种方式](https://blog.csdn.net/chenshanqiang/article/details/103934308)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [AJAX学习笔记——发送AJAX的POST请求,模拟from表单提交](https://blog.csdn.net/weixin_62117675/article/details/127816648)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值