我正在使用plupload允许用户上传文件。我通过plupload传递了两个多参数。页面加载时动态设置第一个参数。当用户从选择菜单中选择时,另一个被设置。
页面加载时,第二个参数为空白,并且用户做出选择后,我不知道如何将其传递给plupload。
如果我将plupload代码添加到change函数中,则可以工作,但是我不希望这样,因为在用户做出选择之前不可见plupload。
我希望有一个人可以帮助我。
这是我的代码:
$("#uType").change(function(){
var upType = $('#uType').val();
$("#type").val(this.value);
});
var uploader = $("#uploader").plupload({
// General settings
runtimes : 'html5,flash,silverlight,html4',
url : "/wp-content/plugins/tyhp-filemaker/tyhp-youth-upload.php",
// Maximum file size
max_file_size : '2mb',
chunk_size: '1mb',
// Resize images on clientside if we can
resize : {
width : 200,
height : 200,
quality : 90,
crop: true // crop to exact dimensions
},
multipart_params: {'type': $('#type').val(), 'account' : $('#AccountUpload').val()},
// Specify what files to browse for
filters : [
{title : "Image files", extensions : "jpg,gif,png"},
{title : "Zip files", extensions : "zip,avi"}
],
// Rename files by clicking on their titles
rename: true,
// Sort files
sortable: true,
// Enable ability to drag'n'drop files onto the widget (currently only HTML5 supports that)
dragdrop: true,
// Views to activate
views: {
list: true,
thumbs: true, // Show thumbs
active: 'thumbs'
}
// Flash settings
flash_swf_url : '/plupload/js/Moxie.swf',
// Silverlight settings
silverlight_xap_url : '/plupload/js/Moxie.xap'
});
最佳答案
我已经找到解决问题的办法。
这是连接到现有的plupload实例并根据选择菜单中的change事件设置多参数的方法:
$("#uType").change(function(){
var upType = $('#uType').val();
$("#type").val(this.value);
var uploader = $('#uploader').plupload('getUploader');
uploader.settings.multipart_params.type = $("#type").val();
uploader.settings.multipart_params.account = $('#AccountUpload').val();
});
关于javascript - 加载动态多参数,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/46286990/