Asp.Net Mvc ajax 文件上传与partialViews?

2024-02-27

是否可以使用部分视图上传ajax文件?

我尝试通过以下方式做到这一点:

Upload.cshtml(部分视图)

<script type="text/javascript">
$(document).ready(function () {
    $("#upload").click(function () {
        var val = $("#galeries").val();
        if (val == null || val == "") {
            val = 0;
        }
        var form = $("#form");
        $.ajax({
            url: form.attr('action'),
            type: form.attr('method'),
            data: { galeryId: val, formElements: form.serialize() },
            complete: function () {

            },
            error: function (jqXhr, textStatus, errorThrown) {
                alert("Error '" + jqXhr.status + "' (textStatus: '" + textStatus + "', errorThrown: '" + errorThrown + "')");
            },
            success: function (data) {

            }
        });
    });
});
</script>

@using (Html.BeginForm("_Upload", "Admin", FormMethod.Post, new { enctype = "multipart/form-data", id = "form" }))
{
    <input type="file" name="file" id="file" />
    <input type="button" value="Yükle" id="upload" />
}

控制器

[HttpPost]
public ActionResult _Upload(IEnumerable<HttpPostedFileBase> files, int galeryId,FormCollection formElements)
{
    foreach (var file in files)
    {
        if (file.ContentLength > 0)
        {
            var fileName = Path.GetFileName(file.FileName);
            var path = Path.Combine(Server.MapPath("~/Images/Galery_" + galeryId), fileName);
            file.SaveAs(path);
        }
    }

    return View();
}

我不知道应该将哪些参数类型传递给控制器​​操作。我就针对这种情况进行了调试。

galeryId = 1;
formElements = "";
files = null;

如果可能(带有部分视图的ajax文件上传),我该怎么办?

Thanks.


序列化方法不适用于文件上传(忽略文件输入类型)。根据您的目标浏览器,您可以使用FormData https://developer.mozilla.org/en-US/docs/DOM/XMLHttpRequest/FormData方法(对于 IE,它必须是 10+),或者开始使用 iframe 来异步发布表单。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Asp.Net Mvc ajax 文件上传与partialViews? 的相关文章

随机推荐