ホームページ >ウェブフロントエンド >jsチュートリアル >jqueryはファイルのアップロードとロードのプログレスバーをドラッグする機能を実装します
この記事では主にHTML5のondropイベントを使ってファイルのアップロードと読み込みの機能を実現するためのjqueryを紹介しています。ファイルのアップロードを実現するには、主に HTML5 の ondrop イベントを使用します。 アップロード コンテンツ チャネル FormData 送信:
//进度条 <p class="parent-dlg" > <p class="progress-label">0%</p> <p class="son"></p> </p> //要拖动到的地方 <p class="main_content_center"></p>
プログレスバー css:
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(); } }
以上が皆さんのためにまとめたものです。将来的には誰にとっても役立ちます。
関連記事:
vue ページ読み込み時のちらつき問題の解決策js による ModelAndView 値の取得の問題についての簡単な説明
vue レンダリング中の {{}} のちらつきの問題とその問題解決策
以上がjqueryはファイルのアップロードとロードのプログレスバーをドラッグする機能を実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。