我在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();;
答案 0 :(得分:6)
在您的FilesAdded事件更改中 uploader.start(); 至 setTimeout('uploader.start()',100);
答案 1 :(得分:1)
答案 2 :(得分:0)
完全!只需在该订单上订购命令:
uploader.init();
uploader.bind('FilesAdded', function(up, files) {
...
uploader.start();
});