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实现分页功能(含ajax请求、后台数据、附完整demo)
Apr 03 jQuery
jQuery Ajax使用FormData上传文件和其他数据后端web.py获取
Jun 11 jQuery
jQuery实现节点的追加、替换、删除、复制功能示例
Jul 11 jQuery
jQuery 循环遍历改变a标签的href(实例讲解)
Jul 12 jQuery
jquery ajaxfileupload异步上传插件
Nov 21 jQuery
jQuery实现模糊查询的方法分析
May 10 jQuery
jQuery实现基本隐藏与显示效果的方法详解
Sep 05 jQuery
jquery.pagination.js分页使用教程
Oct 23 jQuery
jQuery访问json文件中数据的方法示例
Jan 28 jQuery
jQuery中DOM操作原则实例分析
Aug 01 jQuery
jQuery实现轮播图效果demo
Jan 11 jQuery
jQuery表单校验插件validator使用方法详解
Feb 18 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
简单实用的.net DataTable导出Execl
2013/10/28 PHP
destoon各类调用汇总
2014/06/20 PHP
一个PHP实现的轻量级简单爬虫
2015/07/08 PHP
PHP实现求连续子数组最大和问题2种解决方法
2017/12/26 PHP
php设计模式之享元模式分析【星际争霸游戏案例】
2020/03/23 PHP
麦鸡的TAB切换功能结合了javascript和css
2007/12/17 Javascript
自己封装的javascript事件队列函数版
2014/06/12 Javascript
js限制checkbox选中个数以限制六个为例
2014/07/15 Javascript
js控制li的隐藏和显示实例代码
2016/10/15 Javascript
微信小程序 input输入框详解及简单实例
2017/01/10 Javascript
vue学习笔记之指令v-text &amp;&amp; v-html &amp;&amp; v-bind详解
2017/05/12 Javascript
微信小程序获取手机网络状态的方法【附源码下载】
2017/12/08 Javascript
微信小程序App生命周期详解
2018/01/31 Javascript
在vue+element ui框架里实现lodash的debounce防抖
2019/11/13 Javascript
Vue 按照创建时间和当前时间显示操作(刚刚,几小时前,几天前)
2020/09/10 Javascript
[33:15]2018DOTA2亚洲邀请赛3月30日 小组赛B组 VP VS Mineski
2018/03/31 DOTA
Python set集合类型操作总结
2014/11/07 Python
python中requests小技巧
2017/05/10 Python
Python字符串处理实现单词反转
2017/06/14 Python
python 在指定范围内随机生成不重复的n个数实例
2019/01/28 Python
Python爬虫新手入门之初学lxml库
2020/12/20 Python
使用CSS禁止textarea调整大小功能的方法
2015/03/13 HTML / CSS
CSS3 display知识详解
2015/11/25 HTML / CSS
Zavvi美国:英国娱乐之家
2017/03/19 全球购物
SHEIN台湾:购买最新流行女装服饰
2019/05/18 全球购物
ProForm英国站点:健身房和健身器材网上商店
2019/06/05 全球购物
网络工程与软件技术毕业生自荐信
2013/09/24 职场文书
通信工程毕业生自荐信
2013/11/01 职场文书
好的演讲稿开场白
2013/12/30 职场文书
俄罗斯商务邀请函
2014/01/26 职场文书
农民工工资支付承诺函
2014/03/31 职场文书
政风行风建设责任书
2014/07/23 职场文书
2015年安全教育月活动总结
2015/03/26 职场文书
2016年第32个教师节致辞
2015/11/26 职场文书
win11如何查看端口是否被占用? Win11查看端口是否占用的技巧
2022/04/05 数码科技
Spring中的@Transactional的工作原理
2022/06/05 Java/Android