文档章节

HTML5 -- FormData

airmount
 airmount
发布于 2014/06/19 11:08
字数 446
阅读 168
收藏 1

FormData对象是HTML5中新增的一个对象。它能使现在的AJAX交互更加简单。之前的AJAX在上传前,需要将表单的数据序列化,即jQuery中serialize;包括异步上传文件也需要写一大坨“看起来没那么必要 ”的东西。FormData能够简化这些步骤,使AJAX的数据发送变得简单清晰许多 。

FormData有三种用法,一种是创建全新的FormData对象:

1
var formData = new FormData();

一种是获取form表单的FormData对象:

1
2
var form = document.getElementById("form1");
var formData = new FormData(form );

或者通过form的getFormData方法:

1
2
var form = document.getElementById("form1");
var formData = form.getFormData();

获取FormData对象后,还需要向其内部插入数据,目前只能使用append:

1
2
//参数:(name,value);
formData.append("pwd","123456");

当将本地数据添加完毕后,可以通过ajax的send方法传送到服务器。

1
2
3
var xhr = new XMLHttpRequest();
xhr.open('GET'," http://localhost/",true);
xhr.send(formData);

当然FormData并不兼容,这是司徒正美提供的一个兼容的 FormData代码:https://gist.github.com/lemonhall/3120320

FormData在异步上传文件上会更加省事:

1
2
3
4
5
6
7
8
9
10
11
var files = fileInput.files;
var formData = new FormData();
//将所有文件插入formData
for (var i=0; i<files.length; i++) {
    formData.append(fileInput.name, files[i]);
}
             
var xhr = new XMLHttpRequest();
xhr.open('POST'," http://localhost/ajaxload/test.php",true);
//即可上传
xhr.send(formData);

非常简单却非常实用的一个对象。 

本文转载自:http://hi.baidu.com/summer8th/item/35b75bf96397df27753c4c37

共有 人打赏支持
airmount
粉丝 2
博文 2
码字总数 0
作品 0
朝阳
程序员
HTML5 FormData+Ajax上传文件表单

文件表单的数据类事multipart/form-data,因此,formData需要特殊处理. 文件上传 参考文章: HTML5 + AJAX ( 原生JavaScript ) 异步多文件上传 [HTML5] Blob对象 通过Ajax方式上传文件,使用...

IamOkay
2017/10/31
0
0
利用HTML5分片上传超大文件

在网页中直接上传大文件一直是个比较头疼的问题,主要面临的问题一般包括两类:一是上传时间长中途一旦出错会导致前功尽弃;二是服务端配置复杂,要考虑接收超大表单和超时问题,如果是托管主...

miscellanea
2014/09/22
0
0
Html5 FormData+Ajax表单数据提交

首先来认识一下FormData表单 var formData = new FormData(); formData.append('name', 'zhangsan');formData.append('age', 20);formData.append('gender', 'M');//防止跨域,注意,该字符串......

IamOkay
2014/11/25
0
0
利用FormData实现附件上传(实现上传图片显示)

<script type="text/javascript"> function creatXMLHttpRequest(){ var obj =null; if(window.ActiveObject){ obj = new ActiveObject("Microsoft.XMLHTTP");......

PHer
2014/06/23
0
0
初识html5 File API实现带有进度提示的文件上传

Html5终于解决了上传文件的同时显示文件上传进度的老问题。现在大部分的网站用Flash去实现这一功能,还有一些网站继续采用Html <form>with enctype=multipart/form-data,但是需要修改服务器...

miscellanea
2014/06/27
0
3

没有更多内容

加载失败,请刷新页面

加载更多

Shiro | 实现权限验证完整版

写在前面的话 提及权限,就会想到安全,是一个十分棘手的话题。这里只是作为学校Shiro的一个记录,而不是,权限就应该这样设计之类的。 Shiro框架 1、Shiro是基于Apache开源的强大灵活的开源...

冯文议
27分钟前
0
0
linux 系统的运行级别

运行级别 运行级别 | 含义 0 关机 1 单用户模式,可以想象为windows 的安全模式,主要用于修复系统 2 不完全的命令模式,不含NFS服务 3 完全的命令行模式,就是标准的字符界面 4 系统保留 5 ...

Linux学习笔记
今天
2
0
学习设计模式——命令模式

任何模式的出现,都是为了解决一些特定的场景的耦合问题,以达到对修改封闭,对扩展开放的效果。命令模式也不例外: 命令模式是为了解决命令的请求者和命令的实现者之间的耦合关系。 解决了这...

江左煤郎
今天
3
0
字典树收集(非线程安全,后续做线程安全改进)

将500W个单词放进一个数据结构进行存储,然后进行快速比对,判断一个单词是不是这个500W单词之中的;来了一个单词前缀,给出500w个单词中有多少个单词是该前缀. 1、这个需求首先需要设计好数据结...

算法之名
昨天
15
0
GRASP设计模式

此文参考了这篇博客,建议读者阅读原文。 面向对象(Object-Oriented,OO)是当下软件开发的主流方法。在OO分析与设计中,我们首先从问题领域中抽象出领域模型,在领域模型中以适当的粒度归纳...

克虏伯
昨天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部