24

我在 plupload API 文档中没有看到关于将上传的文件数量限制为任意数量,甚至是 1 的选项。

医生失败?或功能失败?如果它不存在,如果有人需要,我会努力实现它..

4

13 回答 13

20

这是一个功能失败。我围绕 jQuery API 做了一个包装器,这就是我所做的让它为我工作的方法。我的代码做了一些其他的业务逻辑,但它应该给你足够的设置开始。

基本上,绑定到FilesAdded事件并调用removeFile上传器对象(如果文件太多)。我想我添加了 50 毫秒超时,因为它给了我文件不存在的问题。

uploader.bind('FilesAdded', function (up, files) {
    var i = up.files.length,
        maxCountError = false;

    plupload.each(files, function (file) {

        if(uploader.settings.max_file_count && i >= uploader.settings.max_file_count){
            maxCountError = true;
            setTimeout(function(){ up.removeFile(file); }, 50);
        }else{
            // Code to add pending file details, if you want
        }

        i++;
    });

    if(maxCountError){
        // Too many files uploaded, do something
    }

});

max_file_count是我在创建 pluploader 实例时添加的东西。


编辑:我实际上不得不为此做两种不同的方式。以上将只允许一个人上传一定数量的文件(否则会产生错误)。

此代码段以类似的方式工作 - 但将删除现有文件并仅上传最新文件:

uploader.bind('FilesAdded', function (up, files) {
    var fileCount = up.files.length,
        i = 0,
        ids = $.map(up.files, function (item) { return item.id; });

    for (i = 0; i < fileCount; i++) {
        uploader.removeFile(uploader.getFile(ids[i]));
    }

    // Do something with file details
});
于 2011-10-31T17:43:02.940 回答
20

其他方法:

 $(document).ready(function () {
    var uploader = new plupload.Uploader({
        ...
        multi_selection: false,
       ....
     });

问候

于 2013-08-08T16:13:24.100 回答
13

基于 Jonathon Bolster 的第二个答案,我编写了这个更简单的代码段来限制上传到最后选择的文件:

uploader.bind('FilesAdded', function(up, files) {
    while (up.files.length > 1) {
        up.removeFile(up.files[0]);
    }
});
于 2012-07-09T00:36:18.187 回答
6

您可以使用它 max_file_count: 5,其中 5 是最大上传数。

于 2011-10-31T17:58:54.357 回答
3

为什么不只是

    if (files.length > 1) uploader.splice(1, files.length - 1);
于 2012-10-08T21:37:55.293 回答
2

试试这个。这对我来说可以。

uploader.bind('FilesAdded', function(up, files) {

if(uploader.files.length > 1)
{
    uploader.removeFile(uploader.files[0]);
    uploader.refresh();// must refresh for flash runtime
}

. . . 餐厅

想法是测试当前上传器对象中的 num 个文件。如果长度大于 1,则只需使用 method uploader.removeFile。请注意,参数 is files[0]which 不是文件 id,而是完整的文件对象。

({id:"p17bqh1v4dp42gdf1gan75p16tp3", name:"gnome-globe.png", size:48456, loaded:0, percent:0, status:1})

最好的祝福!

于 2012-11-12T14:41:46.410 回答
2

现在您可以通过将multi_selection选项设置为false来禁用多选

像这样

var uploader = new plupload.Uploader({
    runtimes : 'html5,flash',
    browse_button : 'button_id',
    multi_selection:false,  //disable multi-selection
...

官方文档在这里:http ://www.plupload.com/documentation.php

于 2013-07-27T17:30:03.637 回答
2
    FilesAdded: function(up, files) {
        up.files.splice(0,up.files.length-1);
    },
    multi_selection: false,

使用up.files,只是filesfiles将始终包含我们从文件浏览器中选择的单个项目。up.files是我们需要缩小到最后选择的文件的实际列表。

于 2015-09-04T12:52:13.587 回答
1

只允许上传一个文件:

uploader.bind('FilesAdded', function(up, files) {
    $.each(files, function(i, file) {
        if(uploader.files.length!=1){uploader.removeFile(file); return;}
    });
});

允许一次选择一个文件:

uploader.bind('FilesAdded', function(up, files) {
    $.each(files, function(i, file) {
        if(i){up.removeFile(file); return;}
    });
});

允许一次上传一个文件:

uploader.bind('FilesAdded', function(up, files) {
    $.each(files, function(i, file) {
        if(uploader.files.length!=1){uploader.removeFile(file); return;}
    });
});
uploader.bind('FileUploaded', function(up, file,response) {
    up.removeFile(file);
});
于 2012-07-17T11:02:43.243 回答
1

如果您想使用自定义上传器,并且一次上传一个文件,则不自动上传并且将最后添加的文件变为新文件,请使用此文件。

uploader.bind('FilesAdded', function(up, files) {
    // Clear the HTML
    $('#plupload-files').html('');

    // Plup does not offer before file added event
    if (up.files.length > 1) {
        up.splice(0, up.files.length);
        up.addFile(files[0])
        return;
    }

    // $.each(files, function(){....
}

我们拼接整个数组,因为 plup 已经将所有文件添加到队列中,如果您像接受的答案一样拼接队列,您实际上将在每次用户尝试添加文件时添加一个文件,并且如果他们尝试单独添加一个新文件它将旧文件保留在 files 数组中的 pos[0] 处,

然后我们添加他们尝试添加的文件的第一个文件。这样,队列中只有一个文件,并且它始终是他们尝试添加的最后一组文件中的第一个文件。

IE。

拖入 plupload 'file1.jpg', 'file2.jpg', 'file3.jpg'

清除整个队列,添加回'file1.jpg'

拖入 plupload 'file4.jpg', 'file5.jpg', 'file6.jpg'

清除整个队列,添加回'file4.jpg'

拖入 plupload 'file99.jpg'

清除整个队列,添加回'file99.jpg'

如果您一次只想上传一个文件,这允许您管理自定义插件。如前所述,其他答案只能工作一次,或者自动开始上传。

于 2013-10-09T04:39:45.283 回答
1

我意识到这已经得到解答,但我采用的解决方案是只使用QueueChanged回调:

QueueChanged: function(uploader) {
    // Called when queue is changed by adding or removing files
    //log('[QueueChanged]');
    if(uploader.files.length > 1) {
        uploader.files.splice(0, (parseInt(uploader.files.length) - 1));
    }
}

使用此代码,它只保留最后选择的文件(以防他们再次选择的原因是因为他们选择了错误的文件)。

于 2015-02-09T20:27:26.073 回答
0

在上传之前直接删除不必要的文件:

$('uploadfiles').onclick = function()
            {
                while (uploader.files.length > 1)
                {
                        uploader.removeFile(uploader.files[0]);
                }

                uploader.start();
                return false;
            };
于 2013-04-04T21:16:35.113 回答
0

在尝试了每个解决方案之后,我想出了最简单的解决方案——这似乎可行。

我正在使用核心 api,并且我将 multi_selection 设置为 false。然后,在选择(添加)第一个文件后,我插入到 FilesAdded 事件中的第二行代码隐藏了浏览链接。我认为这不能用 jquery 小部件来完成,而且我还发现除非上传链接覆盖浏览链接的位置,否则它仍然存在。

uploader.bind('FilesAdded', function(up, files) {
//line below hides button
document.getElementById("browse").style.display = "none";

var html = '';
plupload.each(files, function(file) {
html += '<li id="' + file.id + '">' + file.name + ' (' + plupload.formatSize(file.size) + ') <b></b></li>';
});
document.getElementById('filelist').innerHTML += html;

});

于 2015-01-21T02:36:26.207 回答