分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 前端开发

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

发布时间:2023-09-06 01:45责任编辑:傅花花关键词:文件上传

通过对文件的拖动实现文件的上传,主要用到的是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 实现拖动文件上传加进度条

原文地址:https://www.cnblogs.com/opel/p/8548610.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved