中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

HTML5如何實現拖拽批量上傳文件的案例

發布時間:2020-10-26 09:49:10 來源:億速云 閱讀:221 作者:小新 欄目:web開發

HTML5如何實現拖拽批量上傳文件的案例?這個問題可能是我們日常學習或工作經常見到的。希望通過這個問題能讓你收獲頗深。下面是小編給大家帶來的參考內容,讓我們一起來看看吧!

一、組件描述

  1. 同時拖拽多個文件夾

  2. 刪除指定文件夾

  3. 顯示當前文件夾的上傳進度條

  4. 超過5M的文件夾分片上傳

效果如下:

HTML5如何實現拖拽批量上傳文件的案例

二、遇到的問題

  1. 拖拽讀取每個文件夾下面的文件路徑

  2. 如何顯示當前上傳的文件夾的進度條

  3. 上傳文件時跨域攜帶 cookie

  4. 文件夾分片

三、解決過程

1. 拖拽讀取每個文件夾下面的文件路徑

在進行拖放操作時, DataTransfer 對象用來保存,通過拖放動作,拖動到瀏覽器的數據。它可以保存一項或多項數據、一種或者多種數據類型

// 拖拽文件夾
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('只支持上傳文件夾', '提示', {
      confirmButtonText: '確定'
    })
  }
}

traverseFileTree (item, path, parentDir) {
  path = path || ''
  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 + '/', temp)
      }
    }, function (e) {
      console.log(e)
    })
  }
}

2. 上傳文件夾的進度條

沒有分片的文件:根據文件夾中的文件總數,算出每個文件占文件夾的百分比,當一個文件上傳成功時,修改文件夾 process;

分片的文件:算出每個文件占文件的百分比后,算出每塊文件占文件的百分比,每塊文件上傳成功后,修改文件夾的 process.

3. 跨域攜帶 cookie

服務器設置響應頭

Access-Control-Allow-Origin:必須指定明確的、與請求網頁一致的域名,不能為 *。   Access-Control-Allow-Credentials: true

設置請求頭:

withCredentials:true

補充:

substring 和 substr 的區別

substr(start [, length ]) 返回一個從指定位置開始的指定長度的子字符串。

start:必選項。所需的子字符串的起始位置。字符串中的第一個字符的索引為 0。
length:可選項。在返回的子字符串中應包括的字符個數。

substring 返回位于 String 對象中指定位置的子字符串,返回一個包含從 start 到最后(不包含 end )的子字符串的字符串

start:指明子字符串的起始位置,該索引從 0 開始起算。
end:指明子字符串的結束位置,該索引從 0 開始起算。

感謝各位的閱讀!看完上述內容,你們對HTML5如何實現拖拽批量上傳文件的案例大概了解了嗎?希望文章內容對大家有所幫助。如果想了解更多相關文章內容,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

长岛县| 安徽省| 通城县| 石家庄市| 南郑县| 西华县| 西乌珠穆沁旗| 香河县| 永福县| 大理市| 灯塔市| 治多县| 泽州县| 郎溪县| 平阴县| 台山市| 巧家县| 眉山市| 大邑县| 临湘市| 远安县| 瑞金市| 兖州市| 沂源县| 安泽县| 新宾| 南川市| 孝昌县| 兰西县| 澎湖县| 文昌市| 桂东县| 正定县| 茶陵县| 东宁县| 莎车县| 龙里县| 肇庆市| 阜康市| 绥中县| 日土县|