[英]blueimp jQuery-File-Upload - How do I submit form without files attached?
我在提交文件上傳表單時找到了有關如何添加其他表單數據的解決方案。 如果沒有要上傳的文件,此問題是如何上傳其他數據。
我在任務管理應用程序中使用blueimp jquery-file-upload,以便拖放文件並將它們附加到任務。
該腳本已初始化並設置為在附加文件時不自動上載。 在fileuploadadd
回調中,我將data.submit()
附加到我的submit
事件處理程序。 這實現了我們在一個POST請求中提交任務數據和文件。
在添加文件之前,我無法訪問文件上載data
以使用data.submit()
函數。 我想通過在頁面加載時添加一個空文件(然后刪除它)來解決這個問題,這會觸發將data.submit()
綁定到提交按鈕。 問題是插件在嘗試循環遍歷空文件數組時返回錯誤。 如果您在提交表單之前添加了一個文件然后將其刪除,也會出現此問題。
我一直在尋找一個解決方案,並且看起來高低,但在(恕我直言)可怕的文檔中找不到任何東西。
看看我的代碼如下:
$('#post_task').fileupload({
autoUpload: false,
singleFileUploads: false,
disableImagePreview: true,
}).on('fileuploadadd', function (e, data) {
$.each(data.files, function (index, file) {
var filename = file.name,
filesize = bytesToSize(file.size)
ext = filename.substr(filename.lastIndexOf('.')+1,5),
icon = '<i class="sprite_file sprite_file-file_extension_'+ext+'"></i>',
node = $('<li/>').append($('<span/>').html(icon + filename + ' ' + filesize + '<a href="#">×</a>')).attr('data-index',index);
node.find('a').click(function(e){
e.preventDefault();
var $self = $(this),
$listItem = $self.parents('li'),
listIndex = $listItem.attr('data-index');
$listItem.remove();
$('#files li').attr('data-index',function(index){return index;});
data.files.splice(listIndex,listIndex);
console.log(data);
vardata = data;
});
$('#files').append(node);
});
$('#post_task').unbind('submit').submit(function(ev){
ev.preventDefault();
data.submit();
});
});
我遇到了同樣的問題,如果沒有文件,我最終會在提交之前添加一個空文件。
$("#fileupload").fileupload('add', {
files: ['']
});
這在我的情況下完美地工作,並且后端在提交的文件為空時接收POST。
對於大多數瀏覽器(經過測試的Chrome和FF),我的后端將不會收到任何文件(null),但是IE8中有一個大小為0.我沒有使用任何其他IE測試它。
我剛剛制作了兩個獨立的處理程序:
$('#avatar').fileupload({
singleFileUploads: true,
multipart : true,
dataType : 'json',
autoUpload : false,
url : config.settings.api + 'services/user/updateByActivationKey',
type : 'POST',
add : function (e, data) {
submitbtn.on("click", function () {
console.log('submitting with image');
data.submit();
});
},
done : function (result) {
console.log(result);
if (!result.error) {
$('#modal-account-activated-success').modal('show');
$("#submitbtn").removeAttr('disabled');
$('#mercname').html('');
window.setTimeout(function () {
window.location.href = config.settings.user_url;
}, 3000);
} else {
//analytics.track('completeProfileError', {
// error : JSON.parse(result.responseText).error,
// activationKey: sessionStorage.getItem("activationkey")
//});
$('#modal-account-activated-error').modal('show');
$('#submitloader').html('');
$("#submitbtn").removeAttr('disabled');
}
}
,
fail : function (e) {
//analytics.track('completeProfileError', {
// error : e,
// activationKey: sessionStorage.getItem("activationkey")
//});
$('#errormessage').html(JSON.parse(e.responseText).error.messages[0]);
$('#modal-account-activated-error').modal('show');
$('#submitloader').html('');
$("#submitbtn").removeAttr('disabled');
}
});
//if no image was uploaded
submitbtn.on("click", function () {
if ($('#preview').html().length < 1) {
console.log('submitting without image');
$.ajax({
url : config.settings.api + 'services/user/updateByActivationKey',
type : 'POST',
data : JSON.stringify({
'email' : $("#email").val(),
'activationKey' : $("#activationKey").val(),
'firstName' : $("#firstname").val(),
'lastName' : $("#name").val(),
'password' : $("#password").val(),
'gender' : $("#gender").val(),
'birthdate' : $("#birthdate").val(),
'acceptedTermsAndConditions': $("#checkbox-accept-terms").val(),
'allowsDirectMarketing' : $("#checkbox-allow-marketing").val()
}),
beforeSend: function (xhr) {
xhr.setRequestHeader("Content-Type", "application/json");
},
success : function (result) {
console.log(result);
if (!result.error) {
$('#modal-account-activated-success').modal('show');
$("#submitbtn").removeAttr('disabled');
$('#mercname').html('');
window.setTimeout(function () {
window.location.href = config.settings.user_url;
}, 3000);
} else {
//analytics.track('completeProfileError', {
// error : JSON.parse(result.responseText).error,
// activationKey: sessionStorage.getItem("activationkey")
//});
$('#modal-account-activated-error').modal('show');
$('#submitloader').html('');
$("#submitbtn").removeAttr('disabled');
}
},
error : function (e) {
//analytics.track('completeProfileError', {
// error : e,
// activationKey: sessionStorage.getItem("activationkey")
//});
$('#errormessage').html(JSON.parse(e.responseText).error.messages[0]);
$('#modal-account-activated-error').modal('show');
$('#submitloader').html('');
$("#submitbtn").removeAttr('disabled');
}
})
}
});
@Hirshy和@Luk,你的解決方案非常優雅,就像一個魅力。 文件輸入字段甚至不會被發送到服務器,因此很容易確定文件何時在有效負載中。
在我的Angular應用程序中,我只有一個視圖,用於添加新文檔和一些附帶數據,以及編輯數據和/或上載替換文檔。
這是我的解決方案:
/*------------------------------------------------------------------------*/
/* Prepare file uploader. */
/* */
/* jQuery-File-Upload does not submit a form unless a file has been */
/* selected. To allow this, we manually add an empty file to be uploaded, */
/* which makes the submit handler available, and we replace the submit */
/* handler with one that will submit the form without a selected file. */
/* */
/* see: http://stackoverflow.com/q/21760757/2245849. */
/*------------------------------------------------------------------------*/
var uploadForm = $('#DocumentForm');
var fileInput = $('#DocumentForm input:file');
$scope.uploadOptions =
{
url: Services.Documents.uploadRoute,
autoUpload: false,
dropZone: uploadForm,
fileInput: fileInput,
replaceFileInput: false
};
/*---------------------------------------------------------------*/
/* Initialize the uploader. This must be done with the options */
/* or an error will be thrown when an empty file is added below. */
/* It is also necessary to initialize with the options here as */
/* well as in the element html or the results are unpredictable. */
/*---------------------------------------------------------------*/
uploadForm.fileupload($scope.uploadOptions);
/*--------------------------------------------------------------------*/
/* File processing is called in the default add handler and this */
/* handler is called after a successful add. It displays the file */
/* name in the drop zone, sets the document name for a new document, */
/* and sets the submit handler to submit the form with file and data. */
/* */
/* If editing a document, a dummy empty file object is manually */
/* added to make the submit handler available so the user can make */
/* data changes without uploading a new document. */
/*--------------------------------------------------------------------*/
uploadForm.bind("fileuploadprocessdone", function(e, data)
{
/*------------------------------------------------------------*/
/* Get the user selected file object and display the name. */
/* Set the document name to the file name if not already set. */
/*------------------------------------------------------------*/
if (data.files[0].name)
{
$scope.document.file = data.files[0];
if (!$scope.document.name)
$scope.document.name = $scope.document.file.name;
MessageService.clear();
}
/*--------------------------------------*/
/* If this is the dummy file add, reset */
/* 'acceptFileTypes' to global config. */
/*--------------------------------------*/
else
delete $scope.uploadOptions.acceptFileTypes;
/*------------------------------------------------------------*/
/* Set the submit handler. We have to do this every time a */
/* file is added because 'data' is not passed to the handler. */
/*------------------------------------------------------------*/
uploadForm.unbind('submit').submit(function(e)
{
e.preventDefault();
data.submit();
});
});
/*---------------------------------------------------------------------------*/
/* If we get here, the file could not be added to the process queue most */
/* likely because it is too large or not an allowed type. This is dispatched */
/* after the add event so clear the current file and show the error message. */
/*---------------------------------------------------------------------------*/
uploadForm.bind("fileuploadprocessfail", function(e, data)
{
$scope.document.file = null;
MessageService.notice(data.files[data.index].error);
});
/*-----------------------------------------------------------------*/
/* Add a dummy empty file if not a new document so the submit */
/* handler is set and the user does not have to upload a document. */
/*-----------------------------------------------------------------*/
if (!$scope.new_document)
{
$scope.uploadOptions.acceptFileTypes = null;
uploadForm.fileupload('add', { files: [{}] });
}
UPDATE
結果是uploadForm.fileupload('add', { files: [''] });
如果服務器返回失敗狀態,將導致在瀏覽器中拋出異常。 JFU嘗試分配data.files[0].error
和data.files [0]不存在。
通過分配空數組而不是空字符串來很好地處理問題: uploadForm.fileupload('add', { files: [[]] });
我已經更新了上面的例子。
更新2/29/16
事實證明我確實想要限制文件類型所以我修改了我的腳本以在虛擬文件添加之前清除'acceptFileTypes'屬性並在add處理程序中重置它。 還發現我無法訪問添加處理程序中的進程錯誤,因此將其替換為'fileuploadprocessdone'並處理'fileuploadprocessfail'中的錯誤。
我已經更新了上面的示例,但我們仍在使用JFU 5.42.0。
重要
我使用的是5.42.0,這是JFU的一個非常老的版本。 我沒有寫這個代碼,我第一次嘗試升級失敗了。 當我升級時,我會更新此解決方案。**
試試這個puglin simpleUpload ,不需要表格
HTML:
<input type="file" name="arquivo" id="simpleUpload" multiple >
<button type="button" id="enviar">Enviar</button>
使用Javascript:
$('#simpleUpload').simpleUpload({
url: 'upload.php',
trigger: '#enviar',
success: function(data){
alert('Envio com sucesso');
}
});
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.