这篇文章将为大家详细讲解有关jQuery中jQuery-form.js如何实现异步上传文件,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
一、举个栗子
1.先下载 JQuery-form.js文件并引入,也可以使用CDN,因为是jquery插件,所以需要先引入jquery。
2.html 部分:
<form action='' enctype="multipart/form-data" method="post" name="fileForm">
<input type="file" class="file" name="filename">
</form>
<button class="btn btn-primary" onclick="subimtBtn();">提交</button>
3.js部分:
function subimtBtn() {
var form = $("form[name=fileForm]");
var options = {
url:'/upload', //上传文件的路径
type:'post',
success:function(data){
console.log(data);
//.... //异步上传成功之后的操作
}
};
form.ajaxSubmit(options);
}
这样异步上传就完成了,至于后台对上传的文件的获取,跟前台直接提交表单上传文件的方法是一样的。
二、进一步
还没完呢,上面的例子是直接点击的type=file的input异步上传的,可是大家都知道默认的type=file的input框是很难看的,而且无法自定义样式,这个时候,要想做好看,就需要UI提供一个点击上传文件的图,然后把input隐藏,在点击图片的时候,再用js触发input选择文件,然后再点击提交按钮异步上传。嗯,道理上是这样的,然而是要兼容IE 8的呀亲,不信你在IE8 下面跑跑看,一个 “XXX拒绝访问”的大错误赤裸裸的躺在那儿。
其实这个问题呢,是由于IE的安全机制造成的,对于低版本的IE浏览器来说,如果click事件不是直接穿透到input[type=file]元素上的,那么就会禁止提交,所以你用js触发的input选择文件自然就行不通了。
解决方法:使用label元素。
只需要把上面的form标签里的内容改成下面这样:
<label for="upload">
<img src="upload.png">
</label>
<input type="file" id="upload" class="file" name="filename" style='display:none'>
啊,不对,上面的写法依然不能兼容IE 8,再改改:
<label for="upload">
<input type="file" id="upload" class="file" name="filename" style='opacity:0;filter:alpha(opacity=0);'>
</label>
嗯,就是这样,至于那个好看的点击上传的图片,就作为label元素的背景吧。
相信我,这样真的可以了,兼容IE 8完全没问题。
三、更进一步
可能你还需要判断一下上传的文件类型啥的,比如只让上传excel文件,那请这样写:
$(".file").bind("change",function(){
var fileType = $(this).val().substring($(this).val().lastIndexOf(".") + 1);
if(fileType != "xls" && fileType != "xlsx"){
alert("只能上传excel文件");
}
});
关于“jQuery中jQuery-form.js如何实现异步上传文件”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。