1

在我看来,我得到了以下控件:

<div class="editor-label">
@Html.LabelFor(model => model.Number)
</div>
<div class="editor-field">
@Html.HiddenFor(model => model.Number)
@Html.TextBoxFor(model => model.Number, new { disabled = "disabled" })
</div>
<div class="editor-label">
@Html.LabelFor(model => model.ProjectID)
</div>
<div class="editor-field">
@Html.DropDownListFor(model => model.Project.ID, Model.ProjectList, "Select", new { onchange = "SelectedIndexChanged()" })
</div>

当下拉列表值更改以生成模型的 Number 字段时,我提交表单,然后重新加载视图。当没有 HiddenFor 控件时,模型的 Number 在 TextBoxFor 中正确显示。当我添加一个 HiddenFor 控件时,尽管 Model.Number 不为空,但不会显示 Number 字段。

这是什么原因?

我想要一个带有 Number 值的 HiddenFor 的原因是,当我提交要保存的表单时,model.Number 等于 null。我认为通过将值放入 HiddenFor 我可以访问它...

编辑:控制器方法

    [HttpPost]
    [ValidateAntiForgeryToken]
    public ActionResult CreateOpportunity(CreateEditOpportunityModel model)
    {
        // if the submit is made by the ddl
        if (model.SubmitValue.Equals("ChangeProject"))
        {
            Project parentProject = pCtx.Projects.Find(model.Project.ID);

            if (parentProject != null)
            {   
                // Generate the "Number field"
                Region projectRegion = rCtx.Regions.Find(parentProject.RegionID);
                int numOpportunity = oCtx.Opportunitites.Count(o => o.ProjectID == parentProject.ID);
                numOpportunity++;
                string oppNumber = numOpportunity < 10 ? "0" + numOpportunity : numOpportunity.ToString();
                model.Number = projectRegion.Name + "-" + parentProject.ID + "-" + oppNumber;



            }

            // Repopulate the ddl
            model.ProjectList = new SelectList(pCtx.Projects, "ID", "ID");

            return View(model);
        }

        // if submit is made by the save button
        else if (model.SubmitValue.Equals("CreateOpportunity"))
        {
            if (ModelState.IsValid)
            {
                Opportunity opportunity = new Opportunity();
                opportunity.ID = model.ID;
                opportunity.Number = model.Number;
                opportunity.ActivationDate = model.ActivationDate;
                opportunity.Assignee = model.Assignee;
                opportunity.Comments = model.Comments;
                opportunity.CreationDate = DateTime.Now;
                opportunity.LicenseFilePath = model.LicenseFilePath;
                opportunity.LicenseRequestFilePath = model.LicenseRequestFilePath;
                opportunity.OkPermanentStatus = model.OkPermanentStatus;
                opportunity.PaidStatus = model.PaidStatus;
                opportunity.PartNumber = model.PartNumber;
                opportunity.Project = pCtx.Projects.Find(model.Project.ID);

                //tell EF that Project already exists in Company table
                oCtx.Entry(opportunity.Project).State = EntityState.Modified;

                // Saves project
                oCtx.Opportunitites.Add(opportunity);
                oCtx.SaveChanges();
                return RedirectToAction("Index");
            }

            model.ProjectList = new SelectList(pCtx.Projects, "ID", "ID");

            return View(model);
        }

        model.ProjectList = new SelectList(pCtx.Projects, "ID", "ID");

        return View(model);
    }

这部分代码工作正常,我只是把它放在这里澄清一些事情。

4

0 回答 0