最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-27 19:44:24
文档

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

jquery实现拖动文件上传加载进度条功能:这篇文章主要介绍了jquery 实现拖动文件上传加载进度条功能,主要用到的是HTML5的ondrop事件,非常不错,具有参考借鉴价值,需要的朋友可以参考下通过对文件的拖动实现文件的上传,主要用到的是HTML5的ondrop事件,上传内容通道FormData传输://进度
推荐度:
导读jquery实现拖动文件上传加载进度条功能:这篇文章主要介绍了jquery 实现拖动文件上传加载进度条功能,主要用到的是HTML5的ondrop事件,非常不错,具有参考借鉴价值,需要的朋友可以参考下通过对文件的拖动实现文件的上传,主要用到的是HTML5的ondrop事件,上传内容通道FormData传输://进度


这篇文章主要介绍了jquery 实现拖动文件上传加载进度条功能,主要用到的是HTML5的ondrop事件,非常不错,具有参考借鉴价值,需要的朋友可以参考下

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

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

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;}

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

vue页面加载闪烁问题的解决方法

浅谈js获取ModelAndView值的问题

vue渲染时闪烁{{}}的问题及解决方法

文档

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

jquery实现拖动文件上传加载进度条功能:这篇文章主要介绍了jquery 实现拖动文件上传加载进度条功能,主要用到的是HTML5的ondrop事件,非常不错,具有参考借鉴价值,需要的朋友可以参考下通过对文件的拖动实现文件的上传,主要用到的是HTML5的ondrop事件,上传内容通道FormData传输://进度
推荐度:
标签: 文件 上传 进度条
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top