ajax无刷新上传文件

网页上传文件最简单的方式就是通过表单上传了,但是在提交表单的时候会导致网页刷新,但有的时候我们不想网页刷新,有什么办法呢,我们可以使用ajax上传文件来做到这一点。只有ajax还不行,还需要JavaScript的FormData对象配合才行,且这里我们使用jQuery的ajax。

第一步,创建FormData对象

创建FormData的方式有两种:

1、基于HTML表单

<form action="upload.php" id="uploadForm">
    <input type="file" name="file">
    <input type="text" name="CustomField" value="This is some extra data">
</form>

上面的HTML代码是一个简单的表单,这里form表单可以不用添加enctype="multipart/form-data"的属性

var fd = new FormData($('#uploadForm')[0]);

2、不使用HTML表单

HTML只需要一个file类型的input就可以了

<input type="file" id="file">  

然后创建

var fileInput = $("#file")[0];
var fileObj = fileInput.files[0]; //这里只选择一个文件
var fd = new FormData();
fd.append("file", fileObj);
fd.append("CustomField", "Extra data");

第二步,使用ajax上传

$.ajax({
  url: "upload.php",
  type: "POST",
  data: fd,
  processData: false,  // 不处理数据
  contentType: false   // 不设置内容类型
});

这样就实现了无刷新上传文件了。

更详细的使用说明,包括使用原生的XMLHttpRequest对象提交ajax请求上传文件,可以参考下面的链接:https://developer.mozilla.org/zh-CN/docs/Web/API/FormData/Using_FormData_Objects

 

posted @ 2019-10-31 23:27  jacek  阅读(442)  评论(0编辑  收藏  举报