使用 dropzone 发布正常形式

cle*_*ent 5 ajax asp.net-mvc jquery asp.net-mvc-4 dropzone.js

我按照本教程将 DropZone 包含在传统表单元素中:

HTML

<form id="my-awesome-dropzone" class="dropzone">
  <div class="dropzone-previews"></div> <!-- this is were the previews should be shown. -->

  <!-- Now setup your input fields -->
  <input type="email" name="username" />
  <input type="password" name="password" />

  <button type="submit">Submit data and files!</button>
</form>
Run Code Online (Sandbox Code Playgroud)

和这里的 JS

Dropzone.options.myAwesomeDropzone = { // The camelized version of the ID of the form element

  // The configuration we've talked about above
  autoProcessQueue: false,
  uploadMultiple: true,
  parallelUploads: 100,
  maxFiles: 100,

  // The setting up of the dropzone
  init: function() {
    var myDropzone = this;

    // First change the button to actually tell Dropzone to process the queue.
    this.element.querySelector("button[type=submit]").addEventListener("click", function(e) {
      // Make sure that the form isn't actually being sent.
      e.preventDefault();
      e.stopPropagation();
      myDropzone.processQueue();
    });

    // Listen to the sendingmultiple event. In this case, it's the sendingmultiple event instead
    // of the sending event because uploadMultiple is set to true.
    this.on("sendingmultiple", function() {
      // Gets triggered when the form is actually being sent.
      // Hide the success button or the complete form.
    });
    this.on("successmultiple", function(files, response) {
      // Gets triggered when the files have successfully been sent.
      // Redirect user or notify of success.
    });
    this.on("errormultiple", function(files, response) {
      // Gets triggered when there was an error sending the files.
      // Maybe show form again, and notify user of error
    });
  }

}
Run Code Online (Sandbox Code Playgroud)

它工作得很好,除非用户没有提交文件。根据这篇文章,我必须进行一些编辑:

替换简单的

myDropzone.processQueue();
Run Code Online (Sandbox Code Playgroud)

经过

var form = $(this).closest('#dropzone-form');
                    if (form.valid() == true) { 
                        if (myDropzone.getQueuedFiles().length > 0) {                        
                            myDropzone.processQueue();  
                        } else {                       
                            myDropzone.uploadFiles([]); //send empty 
                        }                                    
                    }        
Run Code Online (Sandbox Code Playgroud)

现在,正如在 stackoverflow 帖子“DropZonejs:提交没有文件的表单”评论中所写的那样,我得到了

Uncaught TypeError: Cannot read property 'status' of undefined
Run Code Online (Sandbox Code Playgroud)

所以我检查了dropzone 问题 687,通过替换 dropzone.js 的一些内容来解决这个问题。这条线

ata.append(this._getParamName(i), files[i], files[i].name);
Run Code Online (Sandbox Code Playgroud)

到那些行

if ( typeof files[i] != "undefined" ) {
  formData.append(this._getParamName(i), files[i], files[i].name);
} else {
  formData.append(this._getParamName(i), "");
} 
Run Code Online (Sandbox Code Playgroud)

现在它正在工作(在模型中使用正确的数据调用控制器)但是进行的调用是 AJAX 调用,我想在我的应用程序的控制器中进行重定向,因此它不起作用。我可以使用一个 URL 作为返回值创建一个 Json,但我必须在后端保留重定向。

控制器示例:

[HttpPost]
        public ActionResult Create(CustomViewModel model)
        {
            // Here I get Request.IsAjaxRequest() = true when form is submitted
            if (ModelState.IsValid)
            {
                var container = DoSomething();
                if (container.HasErrors)
                {
                    SetError(container.ErrorMessage);
                    return RedirectToAction("Index");
                }
            }
            else
            {
                SetAlert("ErrorMessage");
            }
            return RedirectToAction("Index");
        }
Run Code Online (Sandbox Code Playgroud)

我该如何解决这个问题?在此先感谢您的帮助

Mat*_*att 2

我遇到了同样的问题,但没有太多时间来解决它。只是需要让它尽快工作......

这是我的 2 美分;

您可以从控制器返回类似的内容;

return Json(new { ErrorMessage = "", RedirectURL = Url.Action("Get", null, new { id = result.Value.id }, Request.Url.Scheme ) });
Run Code Online (Sandbox Code Playgroud)

并从您发布的 JS 中填写此方法:

this.on("successmultiple", function (files, response) {
                // Gets triggered when the files have successfully been sent.
                // Redirect the user or notify of success.
                var errorMessage = response.ErrorMessage;
                if (errorMessage.length > 0) {
                    alert(errorMessage);
                }
                else {
                    window.location.replace(response.RedirectURL);
                }
};
Run Code Online (Sandbox Code Playgroud)