欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

使用AjaxFileUpload.js实现异步文件上传示例

程序员文章站 2023-11-14 20:17:58
ajax是无法提交文件的,所以在上传图片并预览的时候,我们经常使用ifame的方法实现看似异步的效果。但是这样总不是很方便的,ajaxfilleupload.js对上面的方...
ajax是无法提交文件的,所以在上传图片并预览的时候,我们经常使用ifame的方法实现看似异步的效果。但是这样总不是很方便的,ajaxfilleupload.js对上面的方法进行了一个包装,使得我们不用去管理iframe的一系列操作,也不用影响我们的页面结构,实现异步的文件提交。

html:
复制代码 代码如下:

<input type="file" name="upload" hidden="hidden" id="file_upload" accept=".zip" />

js:
复制代码 代码如下:

$.ajaxfileupload({
url:'${pagecontext.request.contextpath}/manage/br_restorepic.action', //需要链接到服务器地址
secureuri:false,
fileelementid:'file_upload', //文件选择框的id属性
datatype: 'text', //服务器返回的格式,可以是json、xml
success: function (data, status) //相当于java中try语句块的用法
{

$('#restoredialog').html(data);




//alert(data);
},
error: function (data, status, e){ //相当于java中catch语句块的用法

$('#restoredialog').html("上传失败,请重试");
}
});

这个方法还会出现一个问题,就是input只能使用一次的问题,input第二次的onchange将不会被执行,这应该是与浏览器的有关,解决办法就是替换这个input

像这样:
复制代码 代码如下:

$('#file_upload').replacewith('<input type="file" name="upload" hidden="hidden" id="file_upload" accept=".zip" />');