首页 > Web开发 > 详细

ajax无刷新上传文件

时间:2019-11-01 00:51:21      阅读:103      评论:0      收藏:0      [点我收藏+]

网页上传文件最简单的方式就是通过表单上传了,但是在提交表单的时候会导致网页刷新,但有的时候我们不想网页刷新,有什么办法呢,我们可以使用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

 

ajax无刷新上传文件

原文:https://www.cnblogs.com/liyuchuan/p/11774377.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!