簡體   English   中英

一種形式的多個dropzone

[英]Multiple dropzone in one form

我在一個頁面中使用dropzone。 事實上,用戶可以動態添加一個包含DropZone的對象,例如一個城市可以有N個房子,對於每個房子,我讓用戶通過DropZone發送文件。

問題是我無法將上傳的文件綁定到ASP模型。 目前它甚至沒有到達控制器。

這是它生成的HTML:

<div class="house0">
<div class="dropzone dz-clickable" id="houseDropzone0">
<div class="dz-default dz-message" data-dz-message="" style="display: block;">
                    <span>Drop files here to upload</span>
                </div>
            </div>
</div>

<div class="house1">
<div class="dropzone dz-clickable" id="houseDropzone1">
<div class="dz-default dz-message" data-dz-message="" style="display: block;">
                    <span>Drop files here to upload</span>
                </div>
            </div>
</div>

這是我做過的Javascript:

//Foreach houses, create a dropzone element and stock it in the table
var dropzones = [];
var housesList= @Html.Raw(Json.Encode(Model.housesList));
for (var i = 0; i < housesList.length; i++) {
                //create the dropzone for the house
                var currentHouse = housesList[i];
                dropzones.push(createHouseDropzoneForId(currentHouse ,i));
            }


//Instanciate each dropzone
function createActionDropzoneForId(id) {
            return new Dropzone("#actionDropzone" + id,
                {
                    url: "/houseUrl/" + id,
                    paramName: 'houseList[' + id+ '].files',
                    autoProcessQueue: false
                });
        }

//Handle the submit event to process the files alongside the data
$("input[type=submit]").on("click", function (e) {
            e.preventDefault();
            e.stopPropagation();

            var form = $(this).closest('form');
            if (form.valid() == true) {
                var dropzones = dropzones;
                dropzones.forEach(function (element) {
                    if (element.getQueuedFiles().length > 0) {
                        element.processQueue();
                    } else {
                        element.uploadFiles([]); //send empty
                    }
                })

            }

        });

這是應該綁定的模型(在我的ASP控制器中):

城市類:

public class City
    {
        public List<Houses> housesList { get; set; }
        // Other properties as postal code, name, etc
}

HOUSE類:

public class House
    {
        public HttpPostedFileBase[] files { get; set; }
        // Other properties as color, name, etc
}

解決此問題的一種方法是確保您的剃刀視圖包含將使用Dropzone元素綁定到模型的@using(Html.BeginForm)指令。

我注意到你在使用的Dropzone元素的定義中:

...
paramName: 'houseList[' + id+ '].files',
...

這應該是問題的原因,因為您的模型目前期望具有此配置的Dropzones:

...
paramName: 'files',
...

要解決此問題,我建議您通過在模型中定義以下屬性來擴充模型以支持多個dropzones:

public HttpPostedFileBase[] houseList-1-files { get; set; }
public HttpPostedFileBase[] houseList-2-files { get; set; }
public HttpPostedFileBase[] houseList-3-files { get; set; }

還要將dropzone定義修改為:

...
paramName: 'houseList-' + id+ '-files',
...

然后,您可以修改收到的HttpPostedFileBase對象以適合您的使用:

public List<Houses> housesList { get; set; }

通過實例化新的House對象。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM