首页 > web前端 > js教程 > 如何通过 FormData 将完整模型传递到 ASP.NET MVC 控制器?

如何通过 FormData 将完整模型传递到 ASP.NET MVC 控制器?

Susan Sarandon
发布: 2024-12-19 14:31:10
原创
619 人浏览过

How to Pass a Complete Model via FormData to an ASP.NET MVC Controller?

通过 FormData 传递整个模型并在 MVC 中接收它

在 ASP.NET MVC 中,通常需要传递完整的模型对象通过表单传递给控制器​​。但是,简单地将模型附加到 FormData 将导致它在控制器中作为字符串接收,从而使其无法使用。

解决方案:

有效地传递模型通过FormData,可以采用以下方法采用:

  1. 序列化模型:
    利用 jQuery 的 FormData 函数序列化模型。这会将模型转换为 FormData 对象,其中可以包含模型属性和文件输入:

    var formdata = new FormData($('form').get(0));
    登录后复制
  2. 发布 FormData:
    发送通过 AJAX POST 的 FormData 对象请求:

    $.ajax({
      url: '@Url.Action("YourActionName", "YourControllerName")',
      type: 'POST',
      data: formdata,
      processData: false,
      contentType: false,  
    });
    登录后复制
  3. 在控制器中接收模型:
    在控制器操作中,接受模型作为适当类型的参数:

    [HttpPost]
    public ActionResult YourActionName(YourModelType model)
    {
    }
    登录后复制
  4. 可选:处理额外的属性:
    如果模型不包含其他表单数据的属性,您可以手动附加它们:

    formdata.append('someProperty', 'SomeValue');
    登录后复制

按照以下步骤,您可以有效地通过通过 FormData 创建一个模型,并以可用的格式在 MVC 控制器中接收它。

以上是如何通过 FormData 将完整模型传递到 ASP.NET MVC 控制器?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板