FormData对象的使用

时间: 2019-01-21阅读: 4179标签: 对象

一、概述

FormData类型是XMLHttpRequest 2级定义的,它是为序列化表以及创建与表单格式相同的数据提供便利。

作用:1.利用一些键值对来模拟一系列表单控件:即将form中的所有表单元素的namevalue组装成一个queryString;2.异步上传二进制文件

与普通Ajax相比,使用FormData的最大优点:可以异步上传二进制文件。


二、使用

1.创建FormData对象方式

 1).let formdata = new FormData();  创建一个空的FormData对象,可以使用formdata.append(key,value)来添加数据

 2).let formdata = new FormData(form);  使用已有的表单来初始化一个FormData对象。

<form id="upload" method="post" action="">
  <input type="text" name="username" value=""/>
  <input type="password" name="paw" value=""/>
  <input type="button" value="提交"/>
</form>

//获取一个form表单对象
let form = document.getElementById("form");
//用这个表单对象来初始化FormData对象
let formdata = new FormData(form);
//我们可以通过name来访问表单中的字段
formdata.get("username");  //获取username的值
formdata.get("pwd");       //获取pwd的值
//我们也可以添加数据
formdata.append("token","fegahgag54");


2.数据形式

    首先,我们要明确FormData里面存储的数据形式,一对key/value组成一条数据,key是唯一的,一个key可能对应多个value。如果使用表单初始化FormData对象,每一个表单字段对应一条数据,他们的name属性值对应key值,value属性值对应value值。



3.操作方法

3.1获取数据   formdata.get(key)

formdata.get("username");  //获取key为username的第一个值
formdata.getAll("username"); //获取key为username的所有值,返回一个数组

3.2添加数据   formdata.append(key,value)

formdata.append("k1","v1");
formdata.append("k1","v2");
formdata.append("k2","v2");

formdata.getAll("k1");  //["v1","v2"]
formdata.get("k2");  //"v2"

3.3设置/修改数据   formdata.set(key,value)如果key不存在则新增一条数据,如果存在,则会修改对应的value值。

formdata.append("k1","v1");
formdata.set("k1","v2");
formdata.get("k1");  //"v2"

3.4判断是否存在某条数据   formdata.has(key),存在返回true,不存在返回false。

formdata.append("k1","v1");
formdata.has("k1");  //true
formdata.has("k2");  //false

 3.5删除数据   formdata.delete(key);

formdata.append("k1","v1");
formdata.delete("k1");
formdata.get("k1");  //null

3.6遍历 通过entries()或values()来获取一个遍历器

formdata.append("k1","v1");
formdata.append("k2","v2");
for(let [key,value] of formdata.entries()){
  console.log(key +":"+ value)
}
输出:
"k1:v1"
"k2:v2"

formdata.append("k1","v1");
formdata.append("k2","v2");
for(let value of formdata.values()){
  console.log(value)
}
输出:
"v1"
"v2"

  4.发送数据(上传文件不刷新页面)

<input type="file" id="upload"/>
<input type="button" id="upload-btn" value="上传"/>

let btn = document.getElementById("upload-btn");
btn.onclick = function(){
    let file = document.getElementById("upload");
    let formdata = new FormData();
    formdata.append("file",file.files[0]);
    fetch("https://www.baidu.com",{ 
method:'POST',
body:formdata
}).then(d=>{
console.log("result is" + d);
alert("上传成功");
})
}

三、浏览器兼容性



来自:https://www.cnblogs.com/crackedlove/archive/2019/01/19/10292867.html


站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

2.广告联盟: 整理了目前主流的广告联盟平台,如果你有流量,可以作为参考选择适合你的平台点击进入

链接: http://www.fly63.com/article/detial/1849

关闭

Js ES6 Promiss对象

Node.js中,以异步(Async)回调著称,使用了异步,提高了程序的执行效率,但是,代码可读性较差的。假如有几个异步操作,后一个操作需要前一个操作的执行完毕之后返回的数据才能执行下去,如果使用Node.js,就需要一层层嵌套下去

Reflect对象

将Object 对象上的属于语言内部的方法放到 Reflect 对象上,从 Reflect 上获得语言内部的方法 ;修改某些 Object 方法的返回结果,让其变得更合理。让Object的操作都变成函数行为。Reflect 对象的方法与 Proxy 对象的方法一一对应。

Javascript的对象拷贝

Javascript中对象拷贝的多种方式,以及探究一下深拷贝和浅拷贝。在开始之前,我先提一下一些基础知识:Javascript 的对象只是指向内存中某个位置的指针。这些指针是可变的,也就是说,它们可以重新被赋值。因此,单单复制这个指针的结果是,有两个指针指向内存中的同一块地址。

File FileList 和 FileReader 对象详解

File 对象、FileList 对象与 FileReader 对象大家或许不太陌生,常见于文件上传下载操作处理(如处理图片上传预览,读取文件内容,监控文件上传进度等问题)

JS所有内置对象属性和方法汇总

对象,是任何一个开发者都无法绕开和逃避的话题,她似乎有些深不可测,但如此伟大和巧妙的存在,一定值得你去摸索、发现、征服。我们都知道,JavaScript有3大对象,分别是本地对象、内置对象和宿主对象

比较 JavaScript 对象的四种方式

比较 JavaScript 中的原始值非常简单。只需使用任何一种可用的相等运算符即可,例如严格相等运算符:但是对象却有结构化数据,所以比较起来比较困难。

JS构造函数、原型对象、隐含参数this

解析器再调用函数每次都会向函数内部传递一个隐含的参数this,this指向的是一个对象(函数执行的上下文对象),使用工厂的方法创建对象:通过该方法可以大批量的创建对象,这样创建的对象使用的构造函数都是Object,无法区分多种不同类型的对象。

js是面向对象还是基于对象?

以前感觉这两个在本质上没有什么区别,面向对象和基于对象都是对一个抽象的对象拥有一系列的行为和状态,本质都是对象层。我们就能够理解JavaScript面向对象设计的思路。

vue中如何监听一个对象内部的变化?

方法1:对整个obj深层监听,默认第一次绑定的时候不会触发watch监听,值为true时可以在最初绑定的时候执行;方法2 :指定key;方法3:computed

js之global 全局对象 方法

global 作为js的全局对象,但其是无法直接访问的,但是在浏览器中浏览器是将这个对象当做是window对象的一部分,即Date 等Global的属性使用window.Date 可访问到

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!