jQuery实现jQuery-form.js实现异步上传文件


Posted in jQuery onApril 28, 2017

做为一个前端开发,你肯定遇到过这样的需求:异步上传文件,还要兼容IE 8。[纳尼,没遇到过,那你们产品和UI对你也忒好了吧。

遇到这种需求,如果项目不是很赶,可以自己用iframe来做,如果项目比较赶的话,就可以使用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文件");
  }
});

四、小结

嗯,也没啥可小结的,其实form.js是一个全,面支持表单的jQuery插件,有很多表单相关的给你,本篇只是介绍了其中一种功能的用法而已,其他更多的用法,请参照https://github.com/jquery-form/form官方文档。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

jQuery 相关文章推荐
jQuery实现动态删除LI的方法
May 30 jQuery
bootstrap+jQuery 实现下拉菜单中复选框全选和全不选效果
Jun 12 jQuery
jQuery实现可拖动进度条实例代码
Jun 21 jQuery
jQuery实现炫丽的3d旋转星空效果
Jul 04 jQuery
jQuery实现的模仿雨滴下落动画效果
Dec 11 jQuery
jQuery中each和js中forEach的区别分析
Feb 27 jQuery
详解jQuery设置内容和属性
Apr 11 jQuery
JS秒杀倒计时功能完整实例【使用jQuery3.1.1】
Sep 03 jQuery
jquery 插件重新绑定的处理方法分析
Nov 23 jQuery
jQuery+PHP+Ajax实现动态数字统计展示功能
Dec 25 jQuery
jquery传参及获取方式(两种方式)
Feb 13 jQuery
jQuery实现带进度条的轮播图
Sep 13 jQuery
jQuery tip提示插件(实例分享)
Apr 28 #jQuery
jQuery自定义元素右键点击事件(实现案例)
Apr 28 #jQuery
jQuery实现动态添加、删除按钮及input输入框的方法
Apr 27 #jQuery
jquery ui sortable拖拽后保存位置
Apr 27 #jQuery
jquery 禁止鼠标右键并监听右键事件
Apr 27 #jQuery
jQuery EasyUI tree增加搜索功能的实现方法
Apr 27 #jQuery
JS/jquery实现一个网页内同时调用多个倒计时的方法
Apr 27 #jQuery
You might like
上传文件先创建目录 再上传到目录里面去
2010/12/29 PHP
Zend Framework教程之视图组件Zend_View用法详解
2016/03/05 PHP
详解PHP中mb_strpos的使用
2018/02/04 PHP
php apache开启跨域模式过程详解
2019/07/08 PHP
JavaScript Timer实现代码
2010/02/17 Javascript
jQuery多媒体插件jQuery Media Plugin使用详解
2014/12/19 Javascript
简单谈谈Javascript中类型的判断
2015/10/19 Javascript
JS实现求数组起始项到终止项之和的方法【基于数组扩展函数】
2017/06/13 Javascript
Vue中引入样式文件的方法
2017/08/18 Javascript
php中and 和 &amp;&amp;出坑指南
2018/07/13 Javascript
vue2.0 中使用transition实现动画效果使用心得
2018/08/13 Javascript
JavaScript实现预览本地上传图片功能完整示例
2019/03/08 Javascript
vue element-ui实现input输入框金额数字添加千分位
2019/12/29 Javascript
jquery实现抽奖功能
2020/10/22 jQuery
[02:36]DOTA2亚洲邀请赛小组赛精彩集锦:奇迹哥卡尔秀翻全场
2017/03/28 DOTA
多线程爬虫批量下载pcgame图片url 保存为xml的实现代码
2013/01/17 Python
Python实现返回数组中第i小元素的方法示例
2017/12/04 Python
matplotlib设置legend图例代码示例
2017/12/19 Python
Python之用户输入的实例
2018/06/22 Python
用python脚本24小时刷浏览器的访问量方法
2018/12/07 Python
python多进程下实现日志记录按时间分割
2019/07/22 Python
Python3操作YAML文件格式方法解析
2020/04/10 Python
python实现定时发送邮件到指定邮箱
2020/12/23 Python
python网络爬虫实现发送短信验证码的方法
2021/02/25 Python
波兰在线香水店:Perfumy.pl
2019/08/12 全球购物
手工制作的意大利皮革运动鞋:KOIO
2020/01/05 全球购物
人力资源管理专业毕业生自我评价
2013/09/21 职场文书
《雷鸣电闪波尔卡》教学反思
2014/02/23 职场文书
2014各大专业毕业生自我评价
2014/09/17 职场文书
营销与策划实训报告
2014/11/05 职场文书
2014年监理个人工作总结
2014/12/11 职场文书
旷课检讨书范文
2015/01/27 职场文书
污水处理保证书
2015/05/09 职场文书
大学生就业指导课心得体会
2016/01/15 职场文书
Python实现文字pdf转换图片pdf效果
2022/04/03 Python
Python绘制散点图之可视化神器pyecharts
2022/07/07 Python