Form表单提交数据的几种方式,前端高级工程师必备知识

1.当点击登录时,向服务器发生的数据是:username=username&password=password

2.这种默认的提交方式,一般会进行页面的跳转(不成功时跳转到当前页面),而有时我们对弹出框进行数据提交的,希望提交成功则关闭弹出框并刷新父页面,失败则提示失败原因,且弹出框不关闭。此时可以采用ajax进行数据提交

2.Ajax提交form表单

说明:

1.采用ajax异步方式,通过js获取form中所有的inout、select等组件的值,将这些值组成json格式,通过异步的方式与服务器进行交互

2.一般将表单数据传给服务器,服务端处理数据并返回结果信息等

3. form表单提交附件

需要shedinform的entype=“multipart/form-data”并且添加,除此之外还需要将表单的提交方法改成post

而且附件只能通过submit方法提交

4.注意事项

1.当你需要发送一个对象的时候,一定要对纯文本格式进行JSON.stringfig()处理。

2.serializeArray():这是Jquery的方法,目的是为了搜索表单元素内部所有可以搜索的标签的那么和value,然后组合成类似这种形式的对象值:{name:"xxx",value:"xxx"}

3.reduce():则是将序列化之后的值转变为Json数据

4.思考:如何配置$.ajax()中的参数将能完美的和后台协作呢?具体的参数说明如下:

5. Ajax中的参数说明
5.1 contentType

1)其默认值为application/x-www-form-urlencoded; charset=UTF-8----即指定窗体数据被编码为名/值对,这是标准的编码格式。(表单默认的提交数据的格式)

2)对于跨域请求,contentType设置为application/x-www-form-urlencoded, multipart/form-datatext/plain以外

3)text/plain:窗体数据以纯文本形式进行编码,其中不含任何空间或者格式字符

4)application/json:窗体数据以json的书韩剧格式来传递([{},{}])

5.2 data

1)是发送到服务器的数据 ,它被转换成一个查询字符串,如果已经是一个字符串的话则不会转换,查询字符串将被追加到get请求url后面。

2)以防止这种自动转换,对象必须为"{键:值}"格式

2)如果参数是一个数组。jQuery会按照traditional参数的值,将自动转化为一个同名的多址查询字符串。

  • 6
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
form 表单的提交有以下几种方式: 1. GET 方法提交:当表单的 `method` 属性设置为 `GET` 时,表单数据会附加在 URL 的查询参数中,通过 GET 请求发送给服务器。这种方式适用于对数据安全性要求不高、数据量较小的情况,例如搜索表单。 2. POST 方法提交:当表单的 `method` 属性设置为 `POST` 时,表单数据会作为请求的内容体发送给服务器。这种方式适用于传输敏感数据或者数据量较大的情况,例如用户注册或登录表单。 3. AJAX 提交:使用 JavaScript 的 XMLHttpRequest 或 Fetch API,可以通过异步的方式将表单数据发送给服务器。这种方式可以在不刷新整个页面的情况下发送数据,并且可以处理服务器返回的结果,实现无刷新的交互效果。 4. File Upload 提交:当表单包含文件上传字段时,可以使用特殊的 enctype 属性(如 `enctype="multipart/form-data"`)以及相应的后端处理逻辑来实现文件的上传。这种方式适用于需要上传文件的场景,例如上传图片、视频等。 5. 使用 JavaScript 提交:通过 JavaScript 可以监听表单的提交事件,并自定义处理逻辑。可以使用 JavaScript 构建请求并将表单数据发送给服务器,例如使用 Fetch API 或其他 AJAX 库来完成提交操作。 需要注意的是,在表单提交时,通常会通过设置 `action` 属性指定处理表单数据的后端地址。同时,表单字段需要通过 `name` 属性来标识,以便后端能够正确解析和处理数据。 根据具体的需求和场景,可以选择适合的提交方式来实现表单数据的传输和处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值