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实现图片放大点击切换
Jun 06 jQuery
Mui使用jquery并且使用点击跳转新窗口的实例
Aug 19 jQuery
jQuery实现所有验证通过方可提交的表单验证
Nov 21 jQuery
20个最常见的jQuery面试问题及答案
May 23 jQuery
jQuery实现checkbox全选功能完整实例
Jul 12 jQuery
浅析vue-router jquery和params传参(接收参数)$router $route的区别
Aug 03 jQuery
jquery 动态遍历select 赋值的实例
Sep 12 jQuery
JQuery获取可视区尺寸和文档尺寸及制作悬浮菜单示例
May 14 jQuery
jQuery模仿ToDoList实现简单的待办事项列表
Dec 30 jQuery
jQuery 选择器用法基础入门示例
Jan 04 jQuery
jQuery实现的解析本地 XML 文档操作示例
Apr 30 jQuery
jQuery实现朋友圈查看图片
Sep 11 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将图片保存入mysql数据库失败的解决方法
2014/12/27 PHP
php读取远程gzip压缩网页的方法
2014/12/29 PHP
如何使用PHP Embed SAPI实现Opcodes查看器
2015/11/10 PHP
php的api数据接口书写实例(推荐)
2016/09/22 PHP
PHP获取文件扩展名的方法实例总结
2017/06/10 PHP
JavaScript Base64编码和解码,实现URL参数传递。
2006/09/18 Javascript
jQuery使用动态渲染表单功能完成ajax文件下载
2013/01/15 Javascript
jquery $.each 和for怎么跳出循环终止本次循环
2013/09/27 Javascript
JS实现图片产生波纹一样flash效果的方法
2015/02/27 Javascript
javascript中利用柯里化函数实现bind方法【推荐】
2016/04/29 Javascript
js生成随机数(指定范围)的实例代码
2016/07/10 Javascript
基于jQuery实现淡入淡出效果轮播图
2020/07/31 Javascript
原生JS实现图片轮播效果
2016/12/26 Javascript
nodejs构建本地web测试服务器 如何解决访问静态资源问题
2017/07/14 NodeJs
vue.js将时间戳转化为日期格式的实现代码
2018/06/05 Javascript
vue结合axios与后端进行ajax交互的方法
2018/07/06 Javascript
Node批量爬取头条视频并保存方法
2018/09/20 Javascript
微信小程序实现单个卡片左滑显示按钮并防止上下滑动干扰功能
2019/12/06 Javascript
原生js实现无缝轮播图
2020/01/11 Javascript
VUE项目实现主题切换的多种方法
2020/11/26 Vue.js
python结合opencv实现人脸检测与跟踪
2015/06/08 Python
使用python编写udp协议的ping程序方法
2018/04/22 Python
python3.X 抓取火车票信息【修正版】
2018/06/19 Python
利用python实现简易版的贪吃蛇游戏(面向python小白)
2018/12/30 Python
Python2.7实现多进程下开发多线程示例
2019/05/31 Python
django迁移文件migrations的实现
2020/03/31 Python
如何使用pycharm连接Databricks的步骤详解
2020/09/23 Python
python 实现弹球游戏的示例代码
2020/11/17 Python
CSS3制作ajax loader icon实现思路及代码
2013/08/25 HTML / CSS
美国环保妈妈、儿童和婴儿用品购物网站:The Tot
2019/11/24 全球购物
毕业实习个人鉴定范文
2013/12/10 职场文书
一份婚庆公司创业计划书
2014/01/11 职场文书
小学二年级评语
2014/04/21 职场文书
兵马俑导游词
2015/02/02 职场文书
国庆节主题班会
2015/08/15 职场文书
公司年会主持词范文!
2019/05/07 职场文书