实现jQuery-form.js实现异步上传文件
来源:互联网 发布:python splinter教程 编辑:程序博客网 时间:2024/05/21 22:42
用jQuery-form.js插件实现异步上传文件
做为一个前端开发,你肯定遇到过这样的需求:异步上传文件,还要兼容IE 8。[纳尼,没遇到过,那你们产品和UI对你也忒好了吧。]
遇到这种需求,如果项目不是很赶,可以自己用iframe来做,如果项目比较赶的话,就可以使用jquery-form.js插件来实现,方便快捷。
一、举个栗子
先下载 JQuery-form.js文件并引入,也可以使用CDN,因为是jquery插件,所以需要先引入jquery。
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文件"); }});
四、小结
嗯,也没啥可小结的,其实form.js是一个全,面支持表单的jQuery插件,有很多表单相关的给你,本篇只是介绍了其中一种功能的用法而已,其他更多的用法,请参照https://github.com/jquery-form/form‘>官方文档。
就酱啦,下一篇见。
更多内容,请移步我的小站
- jQuery实现jQuery-form.js实现异步上传文件
- 实现jQuery-form.js实现异步上传文件
- 使用jquery.form.js+servlet实现文件异步上传
- 利用jquery.form实现异步上传文件
- 【jQuery】Jquery.form.js实现表单异步提交以及文件上传(带进度条)
- 使用jQuery.form插件实现表单异步提交+上传文件
- java+jquery form实现异步上传文件,并且成功返回
- 使用jQuery.form插件实现表单异步提交+上传文件
- jquery.form实现文件上传
- jfinal+jsp+jquery.form.js+oracle实现上传文件
- 使用jquery.form.js实现无刷新上传文件
- jquery实现文件异步上传
- form配合iframe实现文件异步上传
- jquery的异步提交表单(异步上传文件)及jquery.form.js上传文件注意事项
- 使用jquery-form.js异步上传文件和提交表单
- springmvc结合jquery.form.js异步提交表单上传文件
- 使用jquery.upload.js实现异步上传
- 简单实现:jquery ajax/jquery.form.js + springmvc上传文件,带进度条
- 列表拖动排序
- AngularJs中组件、过滤器、自定义过滤器的使用
- Angular快速入门---过滤器篇
- NSDictionary、NSMutableDictionary的基本用法
- Spring Boot实战之Filter实现使用JWT进行接口认证
- 实现jQuery-form.js实现异步上传文件
- 浅谈Java三大特性--封装
- (四)数据库数据更新
- Mondriaan's Dream 瓷砖覆盖地板 编程之美
- 机器学习(二):懒惰学习——近邻分量
- 搜索之红与黑
- React native ios图片加载不出来
- servlet与JSP内置对象的对应关系
- 搭建简易留言板过程中遇到的问题