formdata 和ajax使用,HTML 中 AJAX 的 FormData 对象介绍和使用 - 文章教程

通常我们提交表单时,会把 form 中的所有表格元素的 name 与 value 组成一个 queryString,提交到后台。这用 jQuery 的方法来说,就是 serialize。但当我们使用 Ajax 提交时,这过程就要变成人工的了。因此 FormData 对象的出现可以减少我们一些工作量。

af72f0f2777140314118fcc1afe4171d.png

想得到一个 FormData 对象,很简单:

formdata = new FormData();

但一个空的 FormData 对象对我们没有意义,因此 W3c 草案提供了三种方案来获取或修改 FormData。

示例1:创建一个空的 FormData 对象,然后再用 append 方法逐个添加键值对:

var formdata = new FormData();

formdata.append("name", "问说");

formdata.append("blog", "http://www.wenjiangs.com");

示例2:取得 form 元素对象,将它作为参数传入 FormData 对象中。

var formobj = document.getElementById("form");

var formdata = new FormData(formobj);

示例3:利用 form 元素对象的 getFormData 方法生成它。

var formobj = document.getElementById("form");

var formdata = formobj.getFormData()

注意,formdata 是一个不透明的对象,现在暂时只有一个 append 可以操作,不能通过序列化手段得到其里面的内容,这实在是遗憾。它的用法现在也只有一个,用于增强型的 XMLHttpRequest 对象的 send 方法中去。

var formElement = document.getElementById("myFormElement");

formData = formElement.getFormData();

formData.append("serialnumber", serialNumber++);

xhr.send(formData);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值