我在一个页面中使用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控制器中):
CITY类:
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
}
答案 0 :(得分:0)
解决此问题的一种方法是确保剃刀视图包含@using(Html.BeginForm)指令,该指令会将Dropzone元素绑定到模型。
在您对所使用的Dropzone元素的定义中,我注意到了
...
paramName: 'houseList[' + id+ '].files',
...
这可能是导致问题的原因,因为您的模型当前希望使用此配置的Dropzone:
...
paramName: 'files',
...
要解决此问题,建议您通过在模型中定义以下属性来扩展模型以支持多个拖放区:
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对象。