new FormData() - FormData对象的作用及用法

一、概述

FormData 对象的使用:
1.用一些键值对来模拟一系列表单控件:即把form中所有表单元素的name与value组装成
一个queryString
2. 异步上传二进制文件。

二、使用

1.FormData对象的操作方法,全部在原型中,自己本身没任何的属性及方法。

 

let formData = new FormData()
formData.append('user', 'yang')
获取 formData.get('user')  //yang
删除 formData.delete('user')
.....

2.使用FormData对象发送文件

HTML部分
<form action="">
        <label for="">
            姓名: <input type="text" name="name">
        </label>
        <label for="">
            文件:<input id="file" type="file" name="file">
        </label>
        <label for="">
            <input type="button" value="保存">
        </label>
</form>
JS部分
var btn = document.querySelector('[type=button]');
btn.onclick = function () {
    // 文件元素
    var file = document.querySelector('[type=file]');
    // 通过FormData将文件转成二进制数据
    var formData = new FormData();
    // 将文件转二进制
    *****注意2******
    formData.append('upload', file.files[0]);
    *****注意1******
    var xhr = new XMLHttpRequest;
    xhr.open('post', 'file.php');
    // 监听上传进度
    xhr.upload.onprogress = function (ev) {
    // 事件对象
    // console.log(ev);

        var percent = (ev.loaded / ev.total) * 100 + '%';

        console.log(percent);

        progress.style.width = percent;
    }

    xhr.send(formData);

    xhr.onreadystatechange = function () {
            if(xhr.readyState == 4 && xhr.status == 200) {
                    //
            }
    }
}

注意1:使用jQuery

 $.ajax({
    url: 'file.php',
    type: 'POST',
    data: formdata,                    // 上传formdata封装的数据
    dataType: 'JSON',
    cache: false,                      // 不缓存
    processData: false,                // jQuery不要去处理发送的数据
    contentType: false,                // jQuery不要去设置Content-Type请求头
    success:function (data) {           //成功回调
        console.log(data);
    }
});

注意2:参数
new FormData的参数是一个DOM对象,而非jQuery对象

var formData = new FormData($("#file")[0]);

三、jQuery的参数序列化方法serialize()

序列表表格内容为字符串,用于 Ajax 请求。 
$("form").serialize()

 

转载于:https://www.cnblogs.com/ycg-myblog/p/10466293.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: new FormData()是一种JavaScript API,用于创建一个空的FormData对象,可以用来传递表单数据或其他类型的数据,例如文件或Blob对象。可以使用append()方法向FormData对象中添加键值对,然后将其传递给服务器端进行处理。它通常用于通过AJAX发送数据。 ### 回答2: 在前端开发中,我们常常需要向服务器发送数据。而向服务器发送数据的方法有很多种,其中就包括使用formData对象。 在JavaScript中,我们可以使用new FormData()方法来创建一个formData对象。创建好formData对象之后,我们可以使用append()方法将需要发送到服务器的数据添加进去。接下来,我们将这个formData对象作为请求中的body部分,并发送给服务器。 formData对象可以添加不同类型的数据,包括字符串、文件、Blob对象等等。formData对象的一个很大的优点是,它能够轻松地在前端将表单中的数据全部封装起来,并且可以将这些数据作为一整个formData对象发送到后端,非常方便。 在JavaScript中,我们可以这样创建一个formData对象: ``` let formData = new FormData(); ``` 接下来,我们可以使用append()方法往formData对象中添加数据: ``` formData.append('username', 'jerry'); formData.append('password', '123456'); formData.append('file', fileObj); ``` 其中,'username'和'password'是需要发送到后端的普通字符串数据,而'file'是需要发送到后端的文件数据。fileObj则是一个文件对象,可以是通过<input type="file">选择文件后获取的。 最后,在发送请求的候,我们可以使用fetch()方法来发送请求,代码如下: ``` fetch(url, { method: 'POST', body: formData }).then(response => { // 处理响应数据的逻辑 }); ``` 在上面的代码中,我们将formData对象作为了请求的body部分,并使用POST请求将它发送到了服务器。服务器在接收到请求,就可以直接从request body中获取到前端所发送的数据了。 总之,formData对象是一种非常方便的前端数据传递方式,它可以将表单中的数据封装为一个对象,并作为整体发送给后端进行处理,减少了多次单独发送请求的麻烦,提高了开发效率。 ### 回答3: FormData是一种将键值对数据结构化的方式,可用于通过XMLHttpRequest发送表单数据。传递对象指的是使用Ajax请求发送一个表单,表单的数据需要通过FormData进行封装,包括文件数据。用法如下: ```javascript const formData = new FormData(); formData.append("username", "test"); formData.append("password", "123456"); formData.append("avatar", file); ``` 上述代码中,我们创建了一个FormData对象,并使用它的append()方法往里面添加了三个属性值对,分别是username和password的字符串数据、以及avatar的二进制数据,这里的file变量需要在HTML中通过input元素的type为file的控件实例化的; 接下来,我们可以使用XMLHttpRequest发送这个FormData,使用方式如下: ```javascript const xhr = new XMLHttpRequest(); xhr.open("POST", "/api/submit"); xhr.send(formData); ``` 以上就是new FormData()传递对象用法。通过FormData,我们可以方便地封装表单数据,同支持文件类型,来实现表单的异步提交。这种方式在前端开发中非常常见,特别是涉及到上传文件的场景,能够大大地提高开发效率,减少代码量。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值