ホームページ >ウェブフロントエンド >jsチュートリアル >JSを利用したファイルドラッグ&ドロップアップロードの実装手順を詳しく解説

JSを利用したファイルドラッグ&ドロップアップロードの実装手順を詳しく解説

php中世界最好的语言
php中世界最好的语言オリジナル
2018-05-23 10:04:502442ブラウズ

この記事では主に、JavaScriptイベントのトリガー、ページ要素属性の動的変更、およびその他の関連操作テクニックを含む、JSによって実装されたファイルのドラッグアンドドロップアップロード機能を紹介します。 JSで実装されたアンドドロップ機能 ドラッグアンドドロップアップロード機能。参考のために皆さんと共有してください。詳細は次のとおりです:

nbsp;html>


<meta>
<title>JS文件拖拽上传</title>
<style>
p{
 width: 300px;
 height: 300px;
 border:1px dashed #000;
 position:absolute;
 top: 50%;
 left: 50%;
 margin:-150px 0 0 -150px;
 text-align:center;
 font:20px/300px &#39;微软雅黑&#39;;
 display:none;
}
</style>
<script>
 window.onload = function () {
  var oBox = document.getElementById(&#39;box&#39;);
  var oM = document.getElementById(&#39;m1&#39;);
  var timer = null;
  document.ondragover = function(){
   clearTimeout(timer);
   timer = setTimeout(function(){
    oBox.style.display = &#39;none&#39;;
   },200);
   oBox.style.display = &#39;block&#39;;
  };
  //进入子集的时候 会触发ondragover 频繁触发 不给ondrop机会
  oBox.ondragenter = function(){
   oBox.innerHTML = &#39;请释放鼠标&#39;;
  };
  oBox.ondragover = function(){
   return false;
  };
  oBox.ondragleave = function(){
   oBox.innerHTML = &#39;请将文件拖拽到此区域&#39;;
  };
  oBox.ondrop = function(ev){
   var oFile = ev.dataTransfer.files[0];
   var reader = new FileReader();
   //读取成功
   reader.onload = function(){
    console.log(reader);
   };
   reader.onloadstart = function(){
    alert(&#39;读取开始&#39;);
   };
   reader.onloadend = function(){
    alert(&#39;读取结束&#39;);
   };
   reader.onabort = function(){
    alert(&#39;中断&#39;);
   };
   reader.onerror = function(){
    alert(&#39;读取失败&#39;);
   };
   reader.onprogress = function(ev){
    var scale = ev.loaded/ev.total;
    if(scale>=0.5){
     alert(1);
     reader.abort();
    }
    oM.value = scale*100;
   };
   reader.readAsDataURL(oFile,&#39;base64&#39;);
   return false;
  };
 };
</script>


<meter></meter>
 <p>请将文件拖拽到此区域</p>

http://tools.jb51.net/code/HtmlJsRun を使用して、次のようにオンラインでテストを実行します:

この記事の事例を読んだ後の方法など、とても興味深いですね。php 中国語 Web サイトの他の関連記事にも注目してください。

推奨読書:

JavaScriptコールバック関数のユースケースの詳細な説明


React Navigationを使用する際の注意点は何ですか

以上がJSを利用したファイルドラッグ&ドロップアップロードの実装手順を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。