Как получить данные из частичного представления ViewModel в основную ViewModel - PullRequest
0 голосов
/ 26 апреля 2019

Я создаю POC-приложение, используя ASP.net MVC5.Я хочу иметь модель представления верхнего уровня, которая содержит данные для всех моделей представления в частичных представлениях.Однако, когда я отправляю форму, она не передает данные в моделях на верхний уровень, который я несколько ожидал, но не хотел, чтобы это произошло.

Просмотр моделей

public class InvoiceViewModel
{
    public InvoiceInfo InvoiceInfo { get; set; }
}

public class InvoiceInfo
{
    [DisplayFormat(DataFormatString = "{0:dd/MM/yyyy}", ApplyFormatInEditMode = true)]
    public DateTime DateRaised { get; set; } = DateTime.Now;
    public int InvoiceNo { get; set; }
    public DateTime FromDate { get; set; }
    public DateTime ToDate { get; set; }
    public Currency InvoiceCurrency { get; set; }
}

Форма отправкиfunction

[HttpPost]
public ActionResult CreateInvoice(InvoiceInfo vm)
{
    if (ModelState.IsValid)
    {
        vm.FromDate = vm.ToDate;
    }

    return View(vm);
}

Основное представление с использованием InvoiceViewModel

@using (Html.BeginForm("CreateInvoice", "Invoice", FormMethod.Post))
{
    @Html.AntiForgeryToken()

    <div class="form-horizontal">
        <hr />
        @Html.Partial("_InvoiceInfo", Model.InvoiceInfo)

        <div class="form-group">
            <div class="col-md-offset-2 col-md-10">
                <input type="submit" value="Create" class="btn btn-default" />
            </div>
        </div>
    </div>
}

Частичное представление '_InvoiceInfo'

<div class="form-horizontal">
    <h4>InvoiceInfo</h4>
    <hr />
    @Html.ValidationSummary(true, "", new { @class = "text-danger" })
    <div class="form-group">
        @Html.LabelFor(model => model.DateRaised, htmlAttributes: new { @class = "control-label col-md-2" })
        <div class="col-md-10">
            @Html.EditorFor(model => model.DateRaised, new { htmlAttributes = new { @class = "form-control datepicker" } })
            @Html.ValidationMessageFor(model => model.DateRaised, "", new { @class = "text-danger" })
        </div>
    </div>

    <div class="form-group">
        @Html.LabelFor(model => model.InvoiceNo, htmlAttributes: new { @class = "control-label col-md-2" })
        <div class="col-md-10">
            @Html.EditorFor(model => model.InvoiceNo, new { htmlAttributes = new { @class = "form-control" } })
            @Html.ValidationMessageFor(model => model.InvoiceNo, "", new { @class = "text-danger" })
        </div>
    </div>
ETC...

Поэтому, когда я нажимаю "Отправить", я ожидаю InvoiceInfoОбъект должен находиться в объекте InvoiceViewModel со всеми соответствующими данными.Это может быть невозможно, но любая помощь будет признательна.

1 Ответ

0 голосов
/ 26 апреля 2019

проще сделать InvoiceInfo : InvoiceViewModel.Бритва @model InvoiceViewModel, таким образом, у вас есть все свойства обеих моделей.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...