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实现选中行变色效果(实例讲解)
Jul 06 jQuery
如何将 jQuery 从你的 Bootstrap 项目中移除(取而代之使用Vue.js)
Jul 17 jQuery
jQuery获取table表中的td标签(实例讲解)
Jul 28 jQuery
jQuery+HTML5实现WebGL高性能烟花绽放动画效果【附demo源码下载】
Aug 18 jQuery
jquery操作ul的一些操作笔记整理(干货)
Aug 31 jQuery
jQuery实现菜单的显示和隐藏功能示例
Jul 24 jQuery
详解jQuery中的easyui
Sep 02 jQuery
jQuery实现购物车的总价计算和总价传值功能
Nov 28 jQuery
详解JQuery基础动画操作
Apr 12 jQuery
jquery图片预览插件实现方法详解
Jul 18 jQuery
jquery将信息遍历到界面上实例代码
Jan 21 jQuery
jQuery实现点击滚动到指定元素上的方法分析
Mar 19 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
BBS(php &amp; mysql)完整版(二)
2006/10/09 PHP
PHP中4个加速、缓存扩展的区别和选用建议
2014/03/12 PHP
PHP的一个完美GIF等比缩放类,附带去除缩放黑背景
2014/04/01 PHP
php入门教程之Zend Studio设置与开发实例
2016/09/09 PHP
PHP实现时间比较和时间差计算的方法示例
2017/07/24 PHP
Javascript String对象扩展HTML编码和解码的方法
2009/06/02 Javascript
基于JQuery实现CheckBox全选全不选
2011/06/27 Javascript
JavaScript面向对象(极简主义法minimalist approach)
2012/07/17 Javascript
javascript 表格内容排序 简单操作示例代码
2014/01/03 Javascript
解决微信浏览器Javascript无法使用window.location.reload()刷新页面
2016/06/21 Javascript
Angular.js 实现数字转换汉字实例代码
2016/07/14 Javascript
Angular Module声明和获取重载实例代码
2016/09/14 Javascript
详解Angular 4.x Injector
2017/05/04 Javascript
在一般处理程序(ashx)中弹出js提示语
2017/08/16 Javascript
微信小程序之滚动视图容器的实现方法
2017/09/26 Javascript
解决使用Vue.js显示数据的时,页面闪现原始代码的问题
2018/02/11 Javascript
React+Antd+Redux实现待办事件的方法
2019/03/14 Javascript
JavaScript如何获取一个元素的样式信息
2019/07/29 Javascript
在Vue项目中用fullcalendar制作日程表的示例代码
2019/08/04 Javascript
node读写Excel操作实例分析
2019/11/06 Javascript
js实现移动端吸顶效果
2020/01/08 Javascript
js中火星坐标、百度坐标、WGS84坐标转换实现方法示例
2020/03/02 Javascript
jquery实现拖拽添加元素功能
2020/12/01 jQuery
[36:05]DOTA2亚洲邀请赛 3.31 小组赛 A组 Liquid vs Optic
2018/04/01 DOTA
Python中集合的内建函数和内建方法学习教程
2015/08/19 Python
一行代码让 Python 的运行速度提高100倍
2018/10/08 Python
python 实现网易邮箱邮件阅读和删除的辅助小脚本
2021/03/01 Python
阿迪达斯奥地利官方商城:adidas.at
2016/10/16 全球购物
Raffaello Network西班牙:意大利拉斐尔时尚购物网
2019/03/12 全球购物
zooplus意大利:在线宠物商店
2019/08/07 全球购物
大学生个人自我鉴定
2013/12/03 职场文书
幼儿园教师教育感言
2014/02/28 职场文书
初中学习计划书范文
2014/09/15 职场文书
电气工程师岗位职责
2015/02/12 职场文书
公司催款律师函
2015/05/27 职场文书
资产移交协议书
2016/03/24 职场文书