使用FormData进行Ajax的上传文件

这次给大家带来使用FormData进行Ajax的上传文件,使用FormData进行Ajax上传文件的注意事项有哪些,下面就是实战案例,一起来看一下。

通过传统的form表单提交的方式上传文件:

Html代码 

    

测试通过Rest接口上传文件

指定文件名:

上传文件:

关键字1:

关键字2:

关键字3:

登录后复制

不过传统的form表单提交会导致页面刷新,但是在有些情况下,我们不希望页面被刷新,这种时候我们都是使用Ajax的方式进行请求的:

Js代码 

$.ajax({    url : "http://localhost:8080/STS/rest/user",    type : "POST",    data : $( '#postForm').serialize(),    success : function(data) {      $( '#serverResponse').html(data);    },    error : function(data) {      $( '#serverResponse').html(data.status + " : " + data.statusText + " : " + data.responseText);    } });

登录后复制

如上,通过$(‘#postForm’).serialize()可以对form表单进行序列化,从而将form表单中的所有参数传递到服务端。

但是上述方式,只能传递一般的参数,上传文件的文件流是无法被序列化并传递的。
不过如今主流浏览器都开始支持一个叫做FormData的对象,有了这个FormData,我们就可以轻松地使用Ajax方式进行文件上传了。

关于FormData及其用法

FormData是什么呢?我们来看看Mozilla上的介绍。

XMLHttpRequest Level 2添加了一个新的接口FormData.利用FormData对象,我们可以通过JavaScript用一些键值对来模拟一系列表单控件,我们还可以使用XMLHttpRequest的send()方法来异步的提交这个”表单”.比起普通的ajax,使用FormData的最大优点就是我们可以异步上传一个二进制文件. 

所有主流浏览器的较新版本都已经支持这个对象了,比如Chrome 7+、Firefox 4+、IE 10+、Opera 12+、Safari 5+。

参见:https://developer.mozilla.org/zh-CN/docs/Web/API/XMLHttpRequest/FormData

这里只展示一个通过from表单来初始化FormData的方式


登录后复制

Js代码 

var oData = new FormData(document.forms.namedItem("fileinfo" )); oData.append( "CustomField", "This is some extra data" ); var oReq = new XMLHttpRequest(); oReq.open( "POST", "stash.php" , true ); oReq.onload = function(oEvent) {    if (oReq.status == 200) {      oOutput.innerHTML = "Uploaded!" ;    } else {      oOutput.innerHTML = "Error " + oReq.status + " occurred uploading your file.
"; } }; oReq.send(oData);

登录后复制

参见:https://developer.mozilla.org/zh-CN/docs/Web/Guide/Using_FormData_Objects

使用FormData,进行Ajax请求并上传文件

这里使用JQuery,但是老版本的JQuery比如1.2是不支持的,最好使用2.0或更新版本:

Html代码 

    

指定文件名:

上传文件:

登录后复制

Js代码 

function doUpload() {    var formData = new FormData($( "#uploadForm" )[0]);    $.ajax({      url: 'http://localhost:8080/cfJAX_RS/rest/file/upload' ,      type: 'POST',      data: formData,      async: false,      cache: false,      contentType: false,      processData: false,      success: function (returndata) {        alert(returndata);      },      error: function (returndata) {        alert(returndata);      }    }); }

登录后复制

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

js+ajaxcap操作json对象循环到表格保存

使用ajax校验注册的用户名是否存在

Ajax操作表单异步上传文件

以上就是使用FormData进行Ajax的上传文件的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2775511.html

(0)
上一篇 2025年3月8日 14:28:59
下一篇 2025年2月21日 12:15:22

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • Ajax请求响应中打开新窗口被拦截应该如何处理

    这次给大家带来Ajax请求响应中打开新窗口被拦截应该如何处理,处理Ajax请求响应中打开新窗口被拦截的注意事项有哪些,下面就是实战案例,一起来看一下。 一、问题描述 ajax 异步请求成功后需要新开窗口打开 url,使用的是 window.…

    编程技术 2025年3月8日
    200
  • 怎么设置Ajax请求成功即刻打开新窗口

    这次给大家带来怎么设置Ajax请求成功即刻打开新窗口,设置Ajax请求成功即刻打开新窗口的注意事项有哪些,下面就是实战案例,一起来看一下。 废话不多说,关键代码如下所示: jQuery.ajax({“type”:”post”,”url”:”…

    编程技术 2025年3月8日
    200
  • jQuery.ajaxWebService请求WebMethod处理Ajax

    这次给大家带来jQuery.ajaxWebService请求WebMethod处理Ajax,jQuery.ajaxWebService请求WebMethod处理Ajax的注意事项有哪些,下面就是实战案例,一起来看一下。 在WebForm下 …

    编程技术 2025年3月8日
    200
  • ajax实现txt文本在页面上弹出

    这次给大家带来ajax实现txt文本在页面上弹出,ajax实现txt文本在页面上弹出的注意事项有哪些,下面就是实战案例,一起来看一下。 使用ajax技术实现点击按钮,将TXT文本里的内容通过弹出框显示到页面上 /*事件会在页面加载完成后触发…

    编程技术 2025年3月8日
    200
  • Ajax怎么实现智能提示关联词搜索

    这次给大家带来Ajax怎么实现智能提示关联词搜索,Ajax实现智能提示关联词搜索的注意事项有哪些,下面就是实战案例,一起来看一下。 一、效果图: 二、实现过程:   思路:  三、部分代码:html: Google 登录后复制 css代码:…

    2025年3月8日
    200
  • ajax怎么实现远程通信功能

    这次给大家带来ajax怎么实现远程通信功能,ajax实现远程通信功能的注意事项有哪些,下面就是实战案例,一起来看一下。 本文实例为大家分享了ajax实现远程通信,供大家参考,具体内容如下 第一个文件:html  ajax解决跨域问题 $.a…

    编程技术 2025年3月8日
    200
  • Ajax的反向使用

    这次给大家带来Ajax的反向使用,Ajax反向使用的注意事项有哪些,下面就是实战案例,一起来看一下。 场景1:当有新邮件的时候,网页自动弹出提示信息而无需用户手动的刷新收件箱。 场景2:当用户的手机扫描完成页面中的二维码以后,页面会自动跳转…

    2025年3月8日
    200
  • Ajax实现加载缓存的loding效果

    这次给大家带来Ajax实现加载缓存的loding效果,Ajax实现加载缓存loding效果的注意事项有哪些,下面就是实战案例,一起来看一下。 Ajax 异步请求的时候,一般都会利用一个动态的 gif小图片来制作一个Ajax Loading …

    2025年3月8日
    200
  • $.ajax()的使用方法(附代码)

    这次给大家带来$.ajax()的使用方法(附代码),$.ajax()使用的注意事项有哪些,下面就是实战案例,一起来看一下。 AJAX 是一种与服务器交换数据的技术,可以在补充在整个页面的情况下更新网页的一部分。接下来通过本文给大家介绍aja…

    编程技术 2025年3月8日
    200
  • Ajax与浏览器缓存的使用详解

    这次给大家带来Ajax与浏览器缓存的使用详解,Ajax与浏览器缓存使用的注意事项有哪些,下面就是实战案例,一起来看一下。 在现代Web应用程序中,前端代码充斥着大量的Ajax请求,如果对于Ajax请求可以使用浏览器缓存,那么可以显著地减少网…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论