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插件之validation插件
Mar 29 jQuery
使用jQuery卸载全部事件的思路详解
Apr 03 jQuery
jQuery实现简单的手风琴效果
Apr 17 jQuery
基于jQuery实现的Ajax 验证用户名唯一性实例代码
Jun 28 jQuery
jQuery实现可兼容IE6的遮罩功能详解
Sep 19 jQuery
jQueryMobile之窗体长内容的缺陷与解决方法实例分析
Sep 20 jQuery
判断jQuery是否加载完成,没完成继续判断的解决方法
Dec 06 jQuery
jQuery实现鼠标响应式透明度渐变动画效果示例
Feb 13 jQuery
jQuery移动端跑马灯抽奖特效升级版(抽奖概率固定)实现方法
Jan 18 jQuery
Easyui 关闭jquery-easui tab标签页前触发事件的解决方法
Apr 28 jQuery
jquery 键盘事件 keypress() keydown() keyup()用法总结
Oct 23 jQuery
jQuery 选择器用法实例分析【prev + next】
May 22 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 版本]
2007/03/20 PHP
PHP explode()函数用法、切分字符串
2012/10/03 PHP
PHP--用万网的接口实现域名查询功能
2012/12/13 PHP
基于PHP读取TXT文件向数据库导入海量数据的方法
2013/04/23 PHP
PHP实现的购物车类实例
2015/06/17 PHP
php文档工具PHP Documentor安装与使用方法
2016/01/25 PHP
javascript的事件描述
2006/09/08 Javascript
十个优秀的Ajax/Javascript实例网站收集
2010/03/31 Javascript
div+css布局的图片连续滚动js实现代码
2010/05/04 Javascript
基于JQuery实现鼠标点击文本框显示隐藏提示文本
2012/02/23 Javascript
jQuery学习笔记 操作jQuery对象 文档处理
2012/09/19 Javascript
JS基于cookie实现来宾统计记录访客信息的方法
2015/08/04 Javascript
jquery+php实现滚动的数字特效
2015/11/29 Javascript
JS组件Bootstrap Table使用实例分享
2016/05/30 Javascript
JS简单实现禁止访问某个页面的方法
2016/09/13 Javascript
js模糊查询实例分享
2016/12/26 Javascript
详解Vue内部怎样处理props选项的多种写法
2018/11/06 Javascript
判断“命令按钮”是否被鼠标单击详解
2019/07/31 Javascript
浅谈javascript事件环微任务和宏任务队列原理
2020/09/12 Javascript
vue的hash值原理也是table切换实例代码
2020/12/14 Vue.js
[56:00]DOTA2上海特级锦标赛主赛事日 - 4 胜者组决赛Secret VS Liquid第一局
2016/03/05 DOTA
Python的Django框架中设置日期和字段可选的方法
2015/07/17 Python
OpenCV-Python实现轮廓检测实例分析
2018/01/05 Python
mac 安装python网络请求包requests方法
2018/06/13 Python
python 数据提取及拆分的实现代码
2019/08/26 Python
澳大利亚领先的睡衣品牌:Peter Alexander
2016/08/16 全球购物
财务助理岗位职责
2013/11/10 职场文书
村官工作鉴定评语
2014/01/27 职场文书
《草原》教学反思
2014/02/15 职场文书
服务承诺书怎么写
2014/05/24 职场文书
运动会演讲稿100字
2014/08/25 职场文书
邓小平理论心得体会
2014/09/09 职场文书
大学生考试作弊检讨书1000字
2014/10/14 职场文书
Python趣味挑战之实现简易版音乐播放器
2021/05/28 Python
Minikube搭建Kubernetes集群
2022/03/31 Servers
Python爬取奶茶店数据分析哪家最好喝以及性价比
2022/09/23 Python