自动启动选项plupload 1.4.3.2

时间:2011-06-03 12:41:56

标签: plupload

我在mvc网站中使用plupload,并希望在选择后立即上传单个文件。我将上传器控件的自动启动设置为true,但这不会激活上传。我也尝试在上传者的'filesadded'委托中调用uploader.start();,但这仅适用于我尝试上传的第二个文件。我在没有UI小部件的情况下使用plupload 1.4.3.2。这是我的代码:

var uploader = new plupload.Uploader({
    runtimes: 'gears,html5,flash,silverlight,browserplus',
    browse_button: 'pickfiles',    
    autostart : true,    
    max_file_size: '10mb',
    url: '/Event/Upload',
    resize: { width: 320, height: 240, quality: 90 },
    flash_swf_url: '/Scripts/pl/plupload.flash.swf',
    silverlight_xap_url: '/Scripts/pl/plupload.silverlight.xap',
    filters: [
    { title: "Image files", extensions: "jpg,gif,png" },
    { title: "Zip files", extensions: "zip" }
]
});
uploader.bind('Init', function (up, params) {
    $('#filelist')[0].innerHTML = "<div>Current runtime: " + params.runtime + "</div>";
});
uploader.bind('Error', function (up, err) {
    $('#filelist').append("<div>Error: " + err.code +
        ", Message: " + err.message +
        (err.file ? ", File: " + err.file.name : "") +
        "</div>"
    );

});
uploader.bind('FilesAdded', function (up, files) {
    for (var i in files) {
        $('#filelist')[0].innerHTML += '<div id="' + files[i].id + '">' + files[i].name + ' (' + plupload.formatSize(files[i].size) + ') <b></b></div>';
    }
    //uploader.start();
});
$('#uploadfiles').click(function (e) {
    uploader.start();
    e.preventDefault();
});

uploader.bind('UploadProgress', function (up, file) {
    $('#' + file.id)[0].getElementsByTagName('b')[0].innerHTML = '<span>' + file.percent + "%</span>";
});

uploader.init();;

3 个答案:

答案 0 :(得分:6)

在您的FilesAdded事件更改中 uploader.start(); 至 setTimeout('uploader.start()',100);

答案 1 :(得分:1)

“确保在init之后绑定它,因为它绑定了默认处理程序。”

more information

(我知道迟到,但我仍然喜欢这个解决方案)

答案 2 :(得分:0)

完全!只需在该订单上订购命令:

uploader.init();
uploader.bind('FilesAdded', function(up, files) {
    ...
    uploader.start();
});