2010-10-05 71 views
1

我有一個強類型的視圖,我想從中插入一些數據。但是,當我點擊提交按鈕時,底層數據模型將作爲參數發佈到控制器。但是當我查看參數的內容時,它並沒有被用戶輸入更新。 這是爲什麼?當我點擊提交按鈕,底層模型沒有得到更新

控制器看起來像;

[HttpGet] 
[Authorize(Roles = "Administrator, AdminAccounts")] 
public ActionResult Add(int? id) 
{ 
    ViewData["LastPerson"] = string.Empty; 

    return View(new EmployeeViewModel()); 
} 

[HttpPost] 
[Authorize(Roles = "Administrator, AdminAccounts")] 
public ActionResult Add(EmployeeViewModel employeeViewModel) 
{ 
    if (ModelState.IsValid) 
    { 
     ViewData["LastPerson"] = employeeViewModel.Employee.Forename + " " + 
           employeeViewModel.Employee.Surname; 
     employeeViewModel.Employee.Add(); 
    } 
    return View(new EmployeeViewModel()); 
} 

該視圖看起來像;

<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/AdminAccounts.master" 
Inherits="System.Web.Mvc.ViewPage<SHP.WebUI.Models.EmployeeViewModel>" %> 

<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server"> 
    Add 
</asp:Content> 

<asp:Content ID="Content2" ContentPlaceHolderID="AdminAccountsContent" runat="server"> 

    <% using (Html.BeginForm("Add", "Employee")) {%> 
     <%: Html.ValidationSummary(true) %> 

     <fieldset> 
      <legend>Add Employee</legend> 
      <table> 
       <tr> 
        <td align="right"> 
       <%: Html.LabelFor(model => model.Employee.Forename) %> 
        </td>      
        <td> 
       <%: Html.EditorFor(model => model.Employee.Forename)%> 
       <%: Html.ValidationMessageFor(model => model.Employee.Forename)%> 
        </td> 
       </tr> 
       <tr> 
        <td align="right"> 

       <%: Html.LabelFor(model => model.Employee.Surname)%> 
        </td>      
        <td> 

       <%: Html.EditorFor(model => model.Employee.Surname)%> 
       <%: Html.ValidationMessageFor(model => model.Employee.Surname)%> 
        </td> 
       </tr> 
       <tr> 
        <td align="right"> 
       <%: Html.LabelFor(model => model.Employee.Middlenames)%> 
        </td>      
        <td> 
       <%: Html.EditorFor(model => model.Employee.Middlenames)%> 
        </td> 
       </tr> 
       <tr> 
        <td align="right"> 
       <%: Html.LabelFor(model => model.Employee.EmployeeNumber)%> 
        </td>      
        <td> 
       <%: Html.EditorFor(model => model.Employee.EmployeeNumber)%> 
       <%: Html.ValidationMessageFor(model => model.Employee.EmployeeNumber)%> 
        </td> 
       </tr> 
       <tr> 
        <td align="right"> 
       <%: Html.LabelFor(model => model.Division.DivisionId) %> 
        </td>      
        <td> 
       <%: Html.DropDownListFor(model => model.Division.DivisionId, Model.DivisionSelectList, "<--Select-->")%> 
       <%: Html.ValidationMessageFor(model => model.Division.DivisionId)%> 
        </td> 
       </tr> 
       <tr> 
        <td align="right"> 
       <%: Html.LabelFor(model => model.Department.DepartmentId) %> 
        </td>      
        <td> 
       <%: Html.DropDownListFor(model => model.Department.DepartmentId, Model.DepartmentSelectList, "<--Select-->")%> 
       <%: Html.ValidationMessageFor(model => model.Department.DepartmentId) %> 
        </td> 
       </tr> 
       <tr> 
        <td align="right"> 
       <%: Html.LabelFor(model => model.Employee.AnnualLeaveAllocation) %> 
        </td>      
        <td> 
       <%: Html.EditorFor(model => model.Employee.AnnualLeaveAllocation)%> 
       <%: Html.ValidationMessageFor(model => model.Employee.AnnualLeaveAllocation)%> 
        </td> 
       </tr> 
       <tr> 
        <td align="right"> 
       <%: Html.LabelFor(model => model.Employee.ChristmasAllocation)%> 
        </td>      
        <td> 
       <%: Html.EditorFor(model => model.Employee.ChristmasAllocation)%> 
       <%: Html.ValidationMessageFor(model => model.Employee.ChristmasAllocation)%> 
        </td> 
       </tr> 
       <tr> 
        <td align="right"> 
       <%: Html.LabelFor(model => model.Employee.EmailAddress)%> 
        </td>      
        <td> 
       <%: Html.EditorFor(model => model.Employee.EmailAddress)%> 
       <%: Html.ValidationMessageFor(model => model.Employee.EmailAddress)%> 
        </td> 
       </tr> 
       <tr> 
        <td align="center" colspan="2" style="padding-top:20px;"> 
        <input type="submit" value="Save" /></td> 
       </tr> 
      </table> 
      <% if (ViewData["LastPerson"].ToString().Length > 0) 
       { %> 
       <p> 
        At time <% Response.Write(DateTime.Now.ToString("T")); %> 
        - You have just entered <%Response.Write(ViewData["LastPerson"].ToString()); %>. 
       </p> 
      <%} %> 
     </fieldset> 

    <% } %> 

    <div> 
     <%: Html.ActionLink("Back to List", "Index") %> 
    </div> 

該模型看起來像;

public class EmployeeViewModel 
{ 
    public Employee Employee; 
    public Department Department; 
    public Division Division; 
    public IList<Department> Departments { get; set; } 
    public IEnumerable<SelectListItem> DepartmentSelectList 
    { 
     get 
     { 
      return this.Departments.Select(item => new SelectListItem 
      { 
       Text = item.DepartmentName, 
       Value = item.DepartmentId.ToString() 
      }); 
     } 
    } 
    public IList<Division> Divisions { get; set; } 
    public IEnumerable<SelectListItem> DivisionSelectList 
    { 
     get 
     { 
      return this.Divisions.Select(item => new SelectListItem 
      { 
       Text = item.DivisionName, 
       Value = item.DivisionId.ToString() 
      }); 
     } 
    } 
    /// <summary> 
    /// EmployeeViewModel() - CONSTRUCTOR 
    ///      Gets all of the divisions. 
    ///      Used to populate the drop down list so that you can assign 
    ///      an employee to a division. 
    /// </summary> 
    public EmployeeViewModel() 
    { 
     this.Employee = new Employee(); 
     this.Departments = new List<Department>(); 
     this.Divisions = new List<Division>(); 
     using (SHPContainerEntities db = new SHPContainerEntities()) 
     { 
      this.Divisions = db.Divisions.ToList(); 
     } 
    } 

回答

1

當您發佈到您的添加控制器時,您只傳入員工而不是EmployeeViewModel。所以你可能想嘗試這樣的:

[HttpPost] 
[Authorize(Roles = "Administrator, AdminAccounts")] 
public ActionResult Add(Employee employee) 
{ 
    var employeeViewModel = new EmployeeViewModel(); 
    if (ModelState.IsValid) 
    { 
     ViewData["LastPerson"] = employee.Forename + " " + employee.Surname; 
     employeeViewModel.Employee = employee; 
     employeeViewModel.Employee.Add(); 
    } 
    return View(employeeViewModel); 
} 
+0

是的工作!謝謝。我很驚訝MVC是這樣工作的,但是嘿嘿。 – arame3333 2010-10-06 07:25:00