0

我正在使用dropzone.js上传多个文件。使用它,我可以从一个文件夹中选择多个文件,并且在选择多个文件时,我只会从我的列表中选择一组文件。

相反,我需要选择一个文件夹(目录)

我可以拖放文件夹。当我单击 dz-clickable 时我应该执行的相同功能

我的 HTML 代码

<div class="dropzone dz-clickable" id="myDrop">
    <div class="dz-default dz-message" data-dz-message="">
        <span>Upload or drag your files here</span>
    </div>
</div>

我的 Javascript 代码

var myDropzone = new Dropzone("div#myDrop", {
addRemoveLinks: true,
autoProcessQueue: false,
parallelUploads: maxParallelCount,
url: "#",
transformFile: function transformFile(file, done) {
  zip = new JSZip();
  zip.file(file.name, file);
  zip.generateAsync(
    {
      type:"blob",
      compression: "DEFLATE"
    }
  ).then(function(content) {
    done(content);
  });
},
init: function() {
    this.on("addedfile", function(file) {
        if (jQuery.inArray(file.name, addedfiles) > -1) {
            myDropzone.removeFile(file);
        }
        if (jQuery.inArray(file.name, DOC_NAMES) == -1) {
            myDropzone.removeFile(file);
        }
        else {
            addedfiles.push(file.name);
            queueCount += 1;
        }
    });
    this.on("removedfile", function(file) {
        console.log(file.name);
        if (jQuery.inArray(file.name, addedfiles) > -1) {
            // addedfiles.pop(file.name);
            var indOfAddedFiles = addedfiles.indexOf(file.name);
            console.log("indOfAddedFiles -> "+ indOfAddedFiles);
            addedfiles.splice(indOfAddedFiles, 1);
            queueCount -= 1;
        }
    })
}

我如何选择一个目录并相应地执行我的过程?有任何想法吗 ?

4

3 回答 3

2

只是为@Sri 提供解决方案的上下文

$("div#dropzoneDiv").dropzone({
            url: '/upload',
            init: function() {
                this.hiddenFileInput.setAttribute("webkitdirectory", true);
            }
        });
于 2019-09-25T16:52:52.113 回答
2

让我回答我的问题

选择文件夹是通过设置属性来webkitdirectory实现truehiddenFileInput

随着type属性,添加喜欢

_this3.hiddenFileInput = document.createElement("input");
_this3.hiddenFileInput.setAttribute("type", "file");
_this3.hiddenFileInput.setAttribute("webkitdirectory", true);
于 2018-06-11T13:54:35.543 回答
0

我不认为 Dropzone.js 允许上传整个目录(或者在他们的文档中没有指定)

于 2018-06-05T15:02:31.860 回答