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+ThinkPHP+Ajax实现即时消息提醒功能实例代码
Mar 21 jQuery
jQuery插件FusionCharts绘制的2D双面积图效果示例【附demo源码】
Apr 11 jQuery
jQuery使用ajax_动力节点Java学院整理
Jul 05 jQuery
简单实现jQuery上传图片显示预览功能
Jun 29 jQuery
jQuery菜单实例(全选,反选,取消)
Aug 28 jQuery
使用jQuery实现两个div中按钮互换位置的实例代码
Sep 21 jQuery
jquery鼠标悬停导航下划线滑出效果
Sep 29 jQuery
jQuery实现遍历XML节点和属性的方法示例
Apr 29 jQuery
jquery获取select选中值的文本,并赋值给另一个输入框的方法
Aug 21 jQuery
jquery实现选项卡切换代码实例
May 14 jQuery
jQuery pager.js 插件动态分页功能实例分析
Aug 02 jQuery
jquery实现轮播图特效
Apr 12 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
php 格式化数字的时候注意数字的范围
2010/04/13 PHP
解密ThinkPHP3.1.2版本之模块和操作映射
2014/06/19 PHP
php生成xml时添加CDATA标签的方法
2014/10/17 PHP
php去除数组中重复数据
2014/11/18 PHP
ASP.NET中使用后端代码注册脚本 生成JQUERY-EASYUI的界面错位的解决方法
2010/06/12 Javascript
禁止你的左键复制实用技巧
2013/01/04 Javascript
原生js实现给指定元素的后面追加内容
2013/04/10 Javascript
node.js中的fs.futimes方法使用说明
2014/12/17 Javascript
jquery实现表单验证并阻止非法提交
2015/07/09 Javascript
JavaScript的Polymer框架中dom-repeat与VM的相关操作
2015/07/29 Javascript
基于Jquery和html5实现炫酷的3D焦点图动画
2016/03/02 Javascript
js实现ctrl+v粘贴上传图片(兼容chrome、firefox、ie11)
2016/03/09 Javascript
JS中的forEach、$.each、map方法推荐
2016/04/05 Javascript
AngularJS之依赖注入模拟实现
2016/08/19 Javascript
javascript宿主对象之window.navigator详解
2016/09/07 Javascript
Vuejs第十一篇组件之slot内容分发实例详解
2016/09/09 Javascript
微信小程序 wxapp内容组件 icon详细介绍
2016/10/31 Javascript
关于ES6的六个小特性(二)
2017/02/20 Javascript
详谈表单重复提交的三种情况及解决方法
2017/08/16 Javascript
jQuery除指定区域外点击任何地方隐藏DIV功能
2017/11/13 jQuery
vue-cli —— 如何局部修改Element样式
2020/10/22 Javascript
python获取本地计算机名字的方法
2015/04/29 Python
Python实现并行抓取整站40万条房价数据(可更换抓取城市)
2016/12/14 Python
tensorflow之变量初始化(tf.Variable)使用详解
2020/02/06 Python
使用python的pyplot绘制函数实例
2020/02/13 Python
python实现IOU计算案例
2020/04/12 Python
Python列表嵌套常见坑点及解决方案
2020/09/30 Python
css3如何绘制一个圆圆的loading转圈动画
2018/01/09 HTML / CSS
日本最大的旅游网站:Rakuten Travel(乐天旅游)
2018/08/02 全球购物
党支部综合考察材料
2014/05/19 职场文书
社区科普工作方案
2014/06/03 职场文书
分公司总经理岗位职责
2014/07/30 职场文书
人事行政主管岗位职责
2015/04/09 职场文书
行政撤诉申请书
2015/05/18 职场文书
2015年教务工作总结
2015/05/23 职场文书
Python+DeOldify实现老照片上色功能
2022/06/21 Python