做为一个前端开发,你肯定遇到过这样的需求:异步上传文件,还要兼容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); }
这样异步上传就完成了,至于后台对上传的文件的获取,跟前台直接提交表单上传文件的方法是一样的。
二、进一步
"htmlcode">
<label for="upload"> <img src="/UploadFiles/2021-04-02/upload.png">啊,不对,上面的写法依然不能兼容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官方文档。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
无争山庄资源网 Copyright www.whwtcm.com
暂无“jQuery实现jQuery-form.js实现异步上传文件”评论...
更新日志
2024年11月15日
2024年11月15日
- 文章.2004-被遗忘的时光【华博音乐】【WAV+CUE】
- 群星《青葱韶歌》原力计划·毕业季企划合辑[FLAC+分轨][661M]
- 群星《抖烧 DSD》抖音神曲 [WAV分轨][992M]
- 庾澄庆《哈林天堂》索尼音乐[WAV+CUE][1G]
- 英雄联盟全球总决赛多久打一次 全球总决赛举办频率介绍
- 第二届老头杯什么时候开始选人 第二届老头杯选人时间介绍
- 英雄联盟第二届老头杯什么时候开始 老头杯s2赛程时间队伍名单汇总
- AI赋能卓越显示技术共筑数字未来:三星显示器产品矩阵亮相2024进博会
- 技术剖析:天玑9400如何打造移动最强GPU和游戏体验?
- 顶级装备 实力登顶:三星显示器双十一焕新升级最后冲刺
- 陈影《绝色靓声》WAV+CUE
- 龚玥《禅是一枝花(6N纯银SQCD)》原抓WAV+CUE
- 刘德丽《寂寞在唱歌HQCD+A2HD5》[WAV+CUE]
- 萧亚轩《钻石糖》金牌大风[WAV+CUE][989M]
- 王菲《王菲精选-菲卖品》环球唱片SHM-SACD[ISO][1.9G]