FormData 接口的append() 方法

FormData 接口的append() 方法 会添加一个新值到 FormData 对象内的一个已存在的键中,如果键不存在则会添加该键。

FormData.set 和 append() 的区别在于,如果指定的键已经存在, FormData.set 会使用新值覆盖已有的值,而 append() 会把新值添加到已有值集合的后面。

提示: 这个方法在 Web Workers 中可用。

语法
这个方法有两个版本:一个有两个参数的版本和一个有三个参数的版本。

formData.append(name, value);
formData.append(name, value, filename);

参数
name
value中包含的数据对应的表单名称。
value
表单的值。可以是USVString 或 Blob (包括子类型,如 File)。
filename 可选
传给服务器的文件名称 (一个 USVString), 当一个 Blob 或 File 被作为第二个参数的时候, Blob 对象的默认文件名是 “blob”。 File 对象的默认文件名是该文件的名称。
注意: 如果你指定一个 Blob 作为数据添加到 FormData 对象中, 文件名会被放在 “Content-Disposition” 头部(常常会根据浏览器变化而变化)传给服务器。

返回值

示例
下面的代码创建了一个空的 FormData 对象:

var formData = new FormData(); // Currently empty

你可以通过 FormData.append 往对象里加入键值对:

formData.append('username', 'Chris');
formData.append('userpic', myFileInput.files[0], 'chris.jpg');

跟常规表单数据一样,你可以使用同一个名称添加多个值 。例如 (为了与PHP命名习惯一致在名称中添加了[]):

formData.append('userpic[]', myFileInput1.files[0], 'chris1.jpg');
formData.append('userpic[]', myFileInput2.files[0], 'chris2.jpg');

这项技术使得多文件上传的处理更加简单,因为所得数据结构更有利于循环。

function forwardWeibo(content, retcode) { var formData = new FormData(); formData.append('pic_src', ''); formData.append('pic_id', ''); formData.append('appkey', ''); formData.append('mid', '5147047155731218'); formData.append('style_type', '1'); formData.append('mark', ''); formData.append('reason', '#1# | #2#' + content + ''); formData.append('location', 'v6_content_home'); formData.append('from_plugin', 0); formData.append('pdetail', ''); formData.append('module', ''); formData.append('page_module_id', ''); formData.append('refer_sort', ''); formData.append('is_comment_base', '0'); formData.append('rank', '0'); formData.append('rankid', ''); formData.append('_t', '0'); formData.append('group_source', 'group_all'); formData.append('rid', '7_0_8_6558451757208053426_0_0_0'); formData.append('isReEdit', false); formData.append('retcode', retcode || ''); var xhr = new XMLHttpRequest(); xhr.timeout = 3000; xhr.responseType = "text"; xhr.open('POST', 'https://weibo.com/aj/v6/mblog/forward?ajwvr=6&domain=5453537583&__rnd' + new Date().getTime(), true); xhr.onload = function(e) { if (this.status == 200 || this.status == 304) { var data = JSON.parse(this.responseText); if (data.code == "100000") { // 转发微博成功 f = 0; console.log(content); } else { // 转发微博失败,其他原因 f++; console.log(data); } } }; xhr.onerror = function() { console.error("Request failed"); }; xhr.ontimeout = function() { console.error("Request timed out"); }; xhr.send(formData); } // 每5秒转发一次 var count = 1; var f = 1; var i = setInterval(function() { if (count < 1390) { forwardWeibo(count++); if (f >= 2) { clearInterval(i); console.log("转发失败次数达到3次,停止执行"); } } }, 5000);
最新发布
03-30
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值