如何使用uploadcare上传多个文件

时间:2018-10-02 23:58:24

标签: javascript jquery uploadcare

我正在尝试为多图像上传实现Uploadcare,但对代码结构感到困惑。下面的代码可以工作,但是它有两个.fail块和两个.done块。另外,应在将组保存到服务器上之后,使用$.each()将图像添加到前端,同时此代码将同时执行这两个操作。

如何改进此代码?

$('button').on('click', function() {

    var myDialog = uploadcare.openDialog(null, {
        imagesOnly: true, multiple: true, multipleMin: 1, multipleMax: 7
    });

    myDialog.fail(function(error, fileInfo) {
        alert('Upload fialed');
    });

    myDialog.done(

        groupInstance => {  
            var groupPromise = groupInstance.promise();
            var arrayOfFiles = groupInstance.files();

            groupPromise.done(function(fileGroupInfo) {
                /* Save group to server using Ajax */
                uploadGroup(fileGroupInfo.uuid);
            });

            groupPromise.fail(function(error, fileGroupInfo) {
                alert('Upload failed');
            });

            $.each(arrayOfFiles, function(i, file) {
                file.done(function(fileInfo) {
                    /* Add image to front-end */
                });
            });
        });

       return false;
    });

还有AJAX功能:

uploadGroup = function(imgurl) {        
    $.post('index.php',
    {string:imgurl},
    function(data) {
        if(data.status=='success') {
            alert('success');
        }
        else {
            alert('error');
        }
    },'json');
};

也对groupInstance =>表示法感到困惑。

1 个答案:

答案 0 :(得分:2)

似乎arrayOfFiles是一个诺言数组?

因此,您等待使用$.when

完成所有操作

并且由于您已经在使用现代javascript,因此您可能不熟悉...,但要添加另一个“奇数”,但这会使事情变得更容易

  

我可能误会了您想等待的时间

   groupInstance => {  
        var groupPromise = groupInstance.promise();
        var arrayOfFiles = groupInstance.files();

        groupPromise.done(function(fileGroupInfo) {
            /* Save group to server using Ajax */
            uploadGroup(fileGroupInfo.uuid);

            // move the .each code here
            $.each(arrayOfFiles, function(i, file) {
                file.done(function(fileInfo) {
                    /* Add image to front-end */
                });
            });

            /* Probably not what you wanted
            $.when(...arrayOfFiles).then((...fileInfos) => {
                $.each(fileInfos, function(i, fileInfo) {
                    // Add image to front-end
                });
            });
            // the above 5 lines in old school JS
            $.when.apply(null, arrayOfFiles).then(function() {
                var fileInfos = [].slice.call(arguments);
                $.each(fileInfos, function(i, fileInfo) {
                    // Add image to front-end
                });
            });
            */
        });

        groupPromise.fail(function(error, fileGroupInfo) {
            alert('Upload failed');
        });
    }

...arayOfFiles ... ...spread syntax ...所以

$.when(...arrayOfFiles)

就像

$.when.apply(null, arrayOfFiles)

并且function(...fileInfos)Rest Syntax

function(...fileInfos) {

等同于

function() {
    fileInfos = [].slice.call(arguments);
}

就像