ファイルのドラッグ アンド ドロップによるバッチ アップロードを実装する HTML5 コード

小云云
リリース: 2018-03-30 11:10:10
オリジナル
3909 人が閲覧しました

この記事では主に、ファイルのドラッグ アンド ドロップによるバッチ アップロード用の HTML5 コードを紹介します。このコンポーネントは Vue.js に基づいて実装されています。完全なデモのアドレスは https://github.com です。 /Msxiaoma/upload-folder をドラッグ アンド ドロップして、フォルダーをアップロードします (Chrome でのみサポートされます)。

1. コンポーネントの説明

  1. 複数のフォルダーを同時にドラッグ

  2. 現在のフォルダーのアップロード進行状況バーを表示

  3. 5Mを超えるフォルダーは分割してアップロードされます

  4. 効果は次のとおりです:

2. 発生した問題

ドラッグアンドドロップして各フォルダーの下のファイルパスを読み取ります

  1. 現在アップロードされているフォルダーの進行状況バーを表示する方法

  2. ファイルをアップロードするときにドメイン間で Cookie を転送します

  3. フォルダーの断片化

  4. 3. 解決プロセス

  5. 1. ドラッグ アンド ドロップして各フォルダーの下のファイル パスを読み取ります

ドラッグ アンド ドロップ操作中に、DataTransfer オブジェクトドラッグ アンド ドロップ アクションによってブラウザにドラッグされたデータを保存するために使用されます。 1 つまたは複数のデータ、1 つまたは複数のデータ型を保存できます

// 拖拽文件夹
dropFolders (e) {
  e.stopPropagation()
  e.preventDefault()
  var items = e.dataTransfer.items
  for (var i = 0; i < items.length; i++) {
    var item = items[i].webkitGetAsEntry()
    if (item) {
      this.checkFolders(item)
    }
  }
}

// 判断是否为文件夹
checkFolders (item) {
  if (item.isDirectory) {
    this.traverseFileTree(item)
  } else {
    this.$alert(&#39;只支持上传文件夹&#39;, &#39;提示&#39;, {
      confirmButtonText: &#39;确定&#39;
    })
  }
}

traverseFileTree (item, path, parentDir) {
  path = path || &#39;&#39;
  if (item.isFile) {
    item.file((file) => {
        let obj = {
          file: file,
          path: path + file.name,
          attr: item.attr
        }
        this.filesList.push(obj)
    })
  } else if (item.isDirectory) {
    var dirReader = item.createReader()
    dirReader.readEntries((entries) => {
      for (let i = 0; i < entries.length; i++) {
        entries[i].attr = item.attr
        this.traverseFileTree(entries[i], path + item.name + &#39;/&#39;, temp)
      }
    }, function (e) {
      console.log(e)
    })
  }
}
ログイン後にコピー

2. 断片化のないフォルダーアップロードの進行状況バー

: フォルダー内のファイルの合計数に応じて、各ファイルの割合を計算します。ファイルが正常にアップロードされたら、フォルダー プロセスを変更します。

断片化されたファイル: ファイル内の各ファイルの割合を計算した後、ファイル内の各ファイルの割合を計算します。 .

3. ドメイン間で Cookie を運ぶ

サーバーが応答ヘッダーを設定するとき

Access-Control-Allow-Origin: 要求された Web ページと一致する明確なドメイン名を指定する必要があり、* は使用できません。 Access-Control-Allow-Credentials: true

Setリクエストヘッダー:

withCredentials:true

補足:

substringとsubstr

substr(start [, length ])の違いは、から始まる値を返します。指定された位置 指定された長さの部分文字列。

開始: 必須。目的の部分文字列の開始位置。文字列の最初の文字のインデックスは 0 です。

長さ: オプション。返される部分文字列に含める必要がある文字数。

substring は、String オブジェクト内の指定された位置にある部分文字列を返し、開始から終了までの部分文字列を含む文字列 (終了を除く) を返します。

start: インデックスが 0 から始まる部分文字列の開始位置を示します。

end: 部分文字列の終了位置を示します。インデックスは 0 から始まります。

以上がファイルのドラッグ アンド ドロップによるバッチ アップロードを実装する HTML5 コードの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート