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插件jquery.viewport.js学习使用方法
Sep 08 jQuery
JQuery用$.ajax或$.getJSON跨域获取JSON数据的实现代码
Sep 23 jQuery
jQuery实现滚动效果
Nov 17 jQuery
jquery+css3实现熊猫tv导航代码分享
Feb 12 jQuery
jQuery实现滚动到底部时自动加载更多的方法示例
Feb 18 jQuery
jQuery AJAX 方法success()后台传来的4种数据详解
Aug 08 jQuery
jQuery仿移动端支付宝键盘的实现代码
Aug 15 jQuery
JQuery扩展对象方法操作示例
Aug 21 jQuery
jQuery实现为动态添加的元素绑定事件实例分析
Sep 07 jQuery
详解jQuery获取特殊属性的值以及设置内容
Nov 14 jQuery
jQuery实现B2B网站后台管理系统侧导航
Jul 08 jQuery
jQuery实现简单弹幕制作
Dec 10 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
福利彩票幸运号码自动生成器
2006/10/09 PHP
php语言流程控制中的主动与被动
2012/11/05 PHP
PHP检测接口Traversable用法详解
2017/12/29 PHP
php生成二维码不保存服务器还有下载功能的实现代码
2018/08/09 PHP
PHP实现函数内修改外部变量值的方法示例
2018/12/28 PHP
用PHP做了一个领取优惠券活动的示例代码
2019/07/05 PHP
javascript实现 在光标处插入指定内容
2007/05/25 Javascript
JavaScript使用技巧精萃[代码非常实用]
2008/11/21 Javascript
IE6背景图片不缓存问题解决方案及图片使用策略多个方法小结
2012/05/14 Javascript
Flexigrid在IE下不显示数据的处理的解决方法
2013/10/24 Javascript
Javascript学习笔记之 函数篇(三) : 闭包和引用
2014/11/23 Javascript
js获取内联样式的方法
2015/01/27 Javascript
关于获取DIV内部内容报错的原因分析及解决办法
2016/01/29 Javascript
浅谈js之字面量、对象字面量的访问、关键字in的用法
2016/11/20 Javascript
babel基本使用详解
2017/02/17 Javascript
Bootstrap学习笔记 轮播(Carousel)插件
2017/03/21 Javascript
说说AngularJS中的$parse和$eval的用法
2017/09/14 Javascript
vue3.0 CLI - 3.2 路由的初级使用教程
2018/09/20 Javascript
傻瓜式解读koa中间件处理模块koa-compose的使用
2018/10/30 Javascript
JavaScript两种计时器的实例讲解
2019/01/31 Javascript
JS中准确判断变量类型的方法
2020/06/01 Javascript
详解Vue3.0 + TypeScript + Vite初体验
2021/02/22 Vue.js
python模拟登陆阿里妈妈生成商品推广链接
2014/04/03 Python
python列表操作实例
2015/01/14 Python
python二分查找算法的递归实现方法
2016/05/12 Python
Python实现对百度云的文件上传(实例讲解)
2017/10/21 Python
python爬虫爬取淘宝商品信息(selenum+phontomjs)
2018/02/24 Python
Python实现的朴素贝叶斯算法经典示例【测试可用】
2018/06/13 Python
Python流程控制 if else实现解析
2019/09/02 Python
Python字符串和正则表达式中的反斜杠('\')问题详解
2019/09/03 Python
荷兰包包购物网站:The Little Green Bag
2018/03/17 全球购物
信电学院毕业生自荐书
2014/05/24 职场文书
教师党的群众路线教育实践活动学习笔记
2014/11/05 职场文书
租车协议书
2015/01/27 职场文书
监护人证明
2015/06/19 职场文书
Python3的进程和线程你了解吗
2022/03/16 Python