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解析获取JSON数据
Apr 08 jQuery
jQuery获取table表中的td标签(实例讲解)
Jul 28 jQuery
jQuery实现上传图片前预览效果功能
Aug 03 jQuery
快速掌握jquery分页插件jqPaginator的使用方法
Aug 09 jQuery
jQuery实现注册会员时密码强度提示信息功能示例
Sep 05 jQuery
jq源码解析之绑在$,jQuery上面的方法(实例讲解)
Oct 13 jQuery
jQuery图片加载失败替换默认图片方法汇总
Nov 29 jQuery
jQuery封装animate.css的实例
Jan 04 jQuery
jQuery实现获取form表单内容及绑定数据到form表单操作分析
Jul 03 jQuery
jQuery md5加密插件jQuery.md5.js用法示例
Aug 24 jQuery
jquery实现二级导航下拉菜单效果实例
May 14 jQuery
JavaScript实现的滚动公告特效【基于jQuery】
Jul 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
php多功能图片处理类分享(php图片缩放类)
2014/03/14 PHP
Laravel 5 框架入门(二)构建 Pages 的管理功能
2015/04/09 PHP
php冒泡排序与快速排序实例详解
2015/12/07 PHP
linux下php上传文件注意事项
2016/06/11 PHP
PHP实现从上往下打印二叉树的方法
2018/01/18 PHP
PHP实现合并两个排序链表的方法
2018/01/19 PHP
php时间戳转换代码详解
2019/08/04 PHP
php解决crontab定时任务不能写入文件问题的方法分析
2019/09/16 PHP
JS通过相同的name进行表格求和代码
2013/08/18 Javascript
js中使用replace方法完成某个字符的转换
2014/08/20 Javascript
javascript实现Email邮件显示与删除功能
2015/11/21 Javascript
js实现界面向原生界面发消息并跳转功能
2016/11/22 Javascript
详解Windows下安装Nodejs步骤
2017/05/18 NodeJs
微信小程序动态显示项目倒计时效果
2017/06/13 Javascript
微信小程序 监听手势滑动切换页面实例详解
2017/06/15 Javascript
vue2.X组件学习心得(新手必看篇)
2017/07/05 Javascript
JS+Ajax实现百度智能搜索框
2017/08/04 Javascript
详解小程序input框失焦事件在提交事件前的处理
2019/05/05 Javascript
vue视图不更新情况详解
2019/05/16 Javascript
iview的table组件自带的过滤器实现
2019/07/12 Javascript
[42:27]DOTA2上海特级锦标赛主赛事日 - 3 败者组第三轮#2Fnatic VS OG第三局
2016/03/05 DOTA
在python的WEB框架Flask中使用多个配置文件的解决方法
2014/04/18 Python
在Python下利用OpenCV来旋转图像的教程
2015/04/16 Python
Django 视图层(view)的使用
2018/11/09 Python
Python进阶之自定义对象实现切片功能
2019/01/07 Python
Python提取频域特征知识点浅析
2019/03/04 Python
Django Haystack 全文检索与关键词高亮的实现
2020/02/17 Python
Python3爬虫中识别图形验证码的实例讲解
2020/07/30 Python
全网最全python库selenium自动化使用详细教程
2021/01/12 Python
python定义具名元组实例操作
2021/02/28 Python
乔迁宴答谢词
2014/01/21 职场文书
实习护士自荐信
2014/06/21 职场文书
研究生简历自我评
2015/03/11 职场文书
python 爬取京东指定商品评论并进行情感分析
2021/05/27 Python
利用python实时刷新基金估值(摸鱼小工具)
2021/09/15 Python
高并发下Redis如何保持数据一致性(避免读后写)
2022/03/18 Redis