HTML5 拖拽批量上传文件的示例代码

建站知识 2021-07-02 23:00www.168986.cn长沙网站建设

拖拽批量上传文件夹

该组件基于 Vue.js 实现,UI 框架是 elementUI,完整的 demo 地址在. 拖拽上传文件夹(仅仅chrome支持)

一、组件描述

  1. 拖拽多个文件夹
  2. 删除指定文件夹
  3. 显示当前文件夹的上传进度条
  4. 超过5M的文件夹分片上传

效果如下

 

二、遇到的问题

  1. 拖拽读取每个文件夹狼蚁网站SEO优化的文件路径
  2. 如何显示当前上传的文件夹的进度条
  3. 上传文件时跨域携带 cookie
  4. 文件夹分片

三、解决过程

1. 拖拽读取每个文件夹狼蚁网站SEO优化的文件路径

在进行拖放操作时, DataTransfer 对象用来保存,通过拖放动作,拖动到浏览器的数据。它可以保存一项或多项数据、一种或者多种数据类型

// 拖拽文件夹
dropFolders (e) {
  e.sPropagation()
  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

当服务器设置响应头

    Aess-Control-Allow-Origin:必须指定明确的、与请求网页一致的域名,不能为 。   Aess-Control-Allow-Credentials: true

设置请求头

    withCredentials:true

补充

substring 和 substr 的区别

substr(start [, length ]) 返回一个从指定位置开始的指定长度的子字符串。

start:必选项。所需的子字符串的起始位置。字符串中的第一个字符的索引为 0。
length:可选项。在返回的子字符串中应包括的字符个数。

substring 返回位于 String 对象中指定位置的子字符串,返回一个包含从 start 到(不包含 end )的子字符串的字符串

start:指明子字符串的起始位置,该索引从 0 开始起算。
end:指明子字符串的结束位置,该索引从 0 开始起算。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by