jquery 实现拖动文件上传加载进度条功能


Posted in jQuery onMarch 18, 2018

通过对文件的拖动实现文件的上传,主要用到的是HTML5的ondrop事件,上传内容通道FormData传输:

//进度条
<div class="parent-dlg" >
 <div class="progress-label">0%</div>
 <div class="son"></div>
</div>
//要拖动到的地方
<div class="main_content_center"></div>

js:

var dz = $('#main_content_center');
dz.ondragover = function(ev) {
 //阻止浏览器默认打开文件的操作
 ev.preventDefault();
}
dz.ondrop = function(ev) {
 ev.preventDefault();
 var files = ev.dataTransfer.files;
 var len = files.length,i = 0;
 while (i < len) {
  var filesName=files[i].name;
  var extStart=filesName.lastIndexOf(".");
  var ext=filesName.substring(extStart,filesName.length).toUpperCase();
  if(ext!=".JPG"&&ext!=".PNG"&&ext!=".XML"){ //判断是否是需要的问件类型
  TS.errorAlert("请选择.jpg、.png、.xml类型的文件上传!");
  return false;
  }else{
  test(files[i]);
  }
  i++;
 }
 $(".parent-dlg").show();
}
function test(a){
 var formData = new FormData();
 formData.append("name", a.name);
 formData.append("size", a.size);
 formData.append("data", a);
 $.ajax({
 url:'',
 type:'post',
 data:formData,
 cache: false,
 processData: false,
 contentType: false,
 xhr: function(){
 var xhr = $.ajaxSettings.xhr();
 if(onprogress && xhr.upload) {
  xhr.upload.addEventListener("progress" , onprogress, false);
  return xhr;
 }
 } 
 })
};
function onprogress(evt){
 var loaded = evt.loaded;  //已经上传大小情况 
 var tot = evt.total;  //附件总大小 
 var per = Math.floor(100*loaded/tot); //已经上传的百分比 
 $(".progress-label").html( per +"%" );
 $(".son").css("width" , per +"%");
 if(per>=100){
 $(".parent-dlg").hide();
 }
 }

 进度条css:

.parent-dlg{position: absolute;width:400px; height:20px; border:1px solid #aaaaaa;border-radius:3px;top:30%;left:50%;z-index:9999;margin-left:-200px;display:none;}
.parent-dlg .progress-label{position: absolute;left: 50%;top: 4px;font-weight: bold;text-shadow: 1px 1px 0 #fff;} 
.parent-dlg .son {width:0; height:100%; background-color:#cccccc; text-align:center; line-height:20px; font-size:16px; font-weight:bold;}

 此内容只是一个大概的文件上传技术方向,可根据自己的项目进行改进! 

总结

以上所述是小编给大家介绍的jquery 实现拖动文件上传加载进度条功能,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

jQuery 相关文章推荐
jQuery实现的背景颜色渐变动画效果示例
Mar 24 jQuery
jQuery实现 RadioButton做必选校验功能
Jun 15 jQuery
详谈表单格式化插件jquery.serializeJSON
Jun 23 jQuery
jQuery之动画ajax事件(实例讲解)
Jul 18 jQuery
简述jQuery Easyui一些用法
Aug 01 jQuery
JS/jQuery实现DIV延时几秒后消失或显示的方法
Feb 12 jQuery
[原创]jQuery实现合并/追加数组并去除重复项的方法
Apr 11 jQuery
JQuery元素快速查找与操作
Apr 22 jQuery
jQuery实现参数自定义的文字跑马灯效果
Aug 15 jQuery
jQuery实现图片下载代码
Jul 18 jQuery
jQuery实现简单弹幕制作
Dec 10 jQuery
Jquery+javascript实现支付网页数字键盘
Dec 21 jQuery
jQuery中each方法的使用详解
Mar 18 #jQuery
jquery点击回车键实现登录效果并默认焦点的方法
Mar 09 #jQuery
JQuery选中select组件被选中的值方法
Mar 08 #jQuery
jQuery+koa2实现简单的Ajax请求的示例
Mar 06 #jQuery
轻松搞定jQuery+JSONP跨域请求的解决方案
Mar 06 #jQuery
jQuery实现左右滑动的toggle方法
Mar 03 #jQuery
jquery radio 动态控制选中失效问题的解决方法
Feb 28 #jQuery
You might like
PHP6 mysql连接方式说明
2009/02/09 PHP
php 分页类 扩展代码
2009/06/11 PHP
PHP抓取、分析国内视频网站的视频信息工具类
2014/04/02 PHP
常见的四种POST 提交数据方式(小总结)
2015/10/08 PHP
Yii2中cookie用法示例分析
2016/07/18 PHP
PHP自定义函数格式化json数据示例
2016/09/14 PHP
php和redis实现秒杀活动的流程
2019/07/17 PHP
动态表格Table类的实现
2009/08/26 Javascript
JavaScript 替换Html标签实现代码
2009/10/14 Javascript
始终在屏幕中间显示Div的代码(css+js)
2011/03/10 Javascript
jquery miniui 教程 表格控件 合并单元格应用
2012/11/25 Javascript
javascript制作坦克大战全纪录(2)
2014/11/27 Javascript
JavaScript数组常用方法
2015/03/02 Javascript
JavaScript使用Prototype实现面向对象的方法
2015/04/14 Javascript
js基础知识(公有方法、私有方法、特权方法)
2015/11/06 Javascript
jquery采用oop模式class类的使用示例
2016/01/22 Javascript
基于BootStrap Metronic开发框架经验小结【三】下拉列表Select2插件的使用
2016/05/12 Javascript
JavaScript中的跨浏览器事件操作的基本方法整理
2016/05/20 Javascript
js微信应用场景之微信音乐相册案例分享
2017/08/11 Javascript
JS中的Replace()传入函数时的用法详解
2017/09/11 Javascript
Node使用Selenium进行前端自动化操作的代码实现
2019/10/10 Javascript
electron 如何将任意资源打包的方法步骤
2020/04/16 Javascript
Python使用lxml模块和Requests模块抓取HTML页面的教程
2016/05/16 Python
不可错过的十本Python好书
2017/07/06 Python
Python设计模式之命令模式原理与用法实例分析
2019/01/11 Python
Python3按一定数据位数格式处理bin文件的方法
2019/01/24 Python
python 实现提取某个索引中某个时间段的数据方法
2019/02/01 Python
Python pip install如何修改默认下载路径
2020/04/29 Python
详解Scrapy Redis入门实战
2020/11/18 Python
美国电子元器件分销商:Newark element14
2018/01/13 全球购物
面试后的英文感谢信
2014/02/01 职场文书
外语系大学生自荐信范文
2014/03/01 职场文书
献爱心倡议书
2014/04/14 职场文书
购房协议书范本(无房产证)
2014/10/07 职场文书
代领报检证委托书范本
2014/10/11 职场文书
mysql幻读详解实例以及解决办法
2022/06/16 MySQL