如何通过Url.Action传递模型?

use*_*018 6 asp.net-mvc

我想在Jquery Dailog中返回一个局部视图,并希望将viewmodel对象传递给特定的控制器动作,该怎么做?

视图

@Html.DropDownListFor(model => model.SelectedCountry, new SelectList(Model.CountryList, "CountryCode", "CountryName"), "---SELECT COUNTRY---",
                                    new { @class = "chosen", @onchange = "this.form.action='/Home/Index'; this.form.submit(); " })
<input type="button" id="button1" value="Push"/>
<div id="dialog" title="Report" style="overflow: hidden;"></div>
Run Code Online (Sandbox Code Playgroud)

JS

<script type="text/javascript">
$(function () {
    $('#dialog').dialog({
        autoOpen: false,
        width: 400,
        resizable: false,
        title: 'Report',
        modal: true,
        open: function() {
            //here how to pass viewmodel
            $(this).load("@Url.Action("CreatePartial")");
        },
        buttons: {
            "Close": function () {
                $(this).dialog("close");
            }
        }
    });

    $('#button1').click(function () {
        $('#dialog').dialog('open');
    });
});
Run Code Online (Sandbox Code Playgroud)

调节器

public ActionResult CreatePartial(HomeViewModel homeViewModel)
{
        return PartialView("_CreatePartial", homeViewModel);
}
Run Code Online (Sandbox Code Playgroud)

目前,"homeViewModel.SelectedCountry"是Null,如何在Jquery中传递模型?

dev*_*214 3

您可以使用内置的 JSON-helper 将模型转换为 JSON 对象,只需将您的请求修改为:

$(this).load('@Url.Action("CreatePartial")',@Html.Raw(Json.Encode(Model)));
Run Code Online (Sandbox Code Playgroud)

需要 @Html.Raw 来防止 HTML 编码。

我测试了它并且它有效。

  • 请注意,它仅适用于小型模型,因为 URL 有长度限制(至少在某些浏览器中)。 (3认同)