我的项目中有以下代码,可以帮助我进行一些非常时髦的 AJAX 上传。
<script>
$(function(){
var uploader = new qq.FileUploader({
action: "{% url ... %}",
element: $('#file-uploader')[0],
multiple: true,
onComplete: function(id, fileName, responseJSON) {
if(responseJSON.success) {
alert("success!");
} else {
alert("upload failed!");
}
},
onAllComplete: function(uploads) {
// uploads is an array of maps
// the maps look like this: {file: FileObject, response: JSONServerResponse}
alert("All complete!");
},
params: {
'csrf_token': '{{ csrf_token }}',
'csrf_name': 'csrfmiddlewaretoken',
'csrf_xname': 'X-CSRFToken',
'iID': '{{ itemID }}',
'received': $('letter_received').val(),
'is_company': $('letter_is_company').val(),
},
});
});
</script>
唯一的问题是我想将额外的 GET 值传递给服务器。我已经尝试了上述方法,但是脚本在页面打开时执行,而不是在值更改时执行。在上面“发送附加参数”下的链接中,作者建议在运行时使用以下代码添加附加值:
uploader.setParams({
anotherParam: 'value'
});
我只是不知道如何访问该uploader
变量。以以下为例:
<button onclick="update_uploader(1,0)">
...
<script>
function update_uploader(received,is_company) {
uploader.setParams({
received: received,
is_company: is_company
});
}
</script>
uploader
由于范围问题,我无法访问。[是的,我尝试过在uploader
外部声明,$(function(){
但它破坏了上传者:(]
有任何想法吗?