视图模型在ASP MVC中传递NULL
本文关键字:NULL MVC 模型 ASP 视图 | 更新日期: 2023-09-27 18:14:31
我正在使用c#和SQL Server 2005开发一个asp.net MVC 3应用程序。我也使用实体框架和代码第一方法。我有一个视图'索引'包含一个链接到另一个视图'更新'。调试时,view的值为NULL的问题。
该视图由名为ProfileGa的控制器填充。
是控制器ProfileGa的一部分代码:
public ActionResult Update(string id)
{
FlowViewModel flv = db.FlowViewModels.Find(id);
return View(flv);
}
[HttpPost]
public ActionResult Update(FlowViewModel model)
{
Console.WriteLine("" + model.Nbr_Passage);
Gamme G = new Gamme();
ListG.Remove(G);
db.Gammes.Remove(G);
G.ID_Gamme = model.SelectedProfile_Ga;
G.ID_Poste = model.SelectedPoste;
G.Last_Posts = model.PostePrecedentSelected;
G.Next_Posts = model.PosteSuivantSelected;
G.Nbr_Passage = int.Parse(model.Nbr_Passage);
G.Position = int.Parse(model.Position);
ListG.Add(G);
db.Gammes.Add(G);
db.SaveChanges();
return RedirectToAction("Index");
}
当我在行上放置一个断点时:
FlowViewModel flv = db.FlowViewModels.Find(id);
flv的值为NULL。可能数据库中没有指定id的记录。
我不能深入讨论Find方法,因为这个方法的代码是预定义的(我没有写它)。它是DbSet的一个方法。
同样的代码在其他视图中工作,但只有这个。
我认为这个问题取决于ID (ID_Gamme),这是一个下拉列表不像其他人(TextBox)。
这是view Index代码的一部分,包含了view的链接。
<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.master" Inherits="System.Web.Mvc.ViewPage<MvcApplication2.Models.FlowViewModel>" %>
<%@ Import Namespace="Helpers" %>
<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server">
Index
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
<table>
<% foreach (var item in Model.GaItems) { %>
<tr>
<td>
<%: Html.DisplayFor(modelItem => item.ID_Gamme) %>
</td>
<td>
<%: Html.DisplayFor(modelItem => item.ID_Poste) %>
</td>
<td>
<%: Html.DisplayFor(modelItem => item.Nbr_Passage) %>
</td>
<td>
<%: Html.DisplayFor(modelItem => item.Position) %>
</td>
<td>
<%: Html.DisplayFor(modelItem => item.Last_Posts) %>
</td>
<td>
<%: Html.DisplayFor(modelItem => item.Next_Posts) %>
</td>
<td>
<%: Html.ActionLink("Modifier", "Update", new { id=item.ID_Gamme }) %>
</td>
</tr>
<% } %>
</table>
</asp:Content>
,这是模型FlowViewModel的代码:
public class FlowViewModel
{
[Key]
public string IDv { get; set; }
[NotMapped]
public SelectList PostesItems { get; set; }
public List<Profile_Ga> Profile_GaItems { get; set; }
public List<Gamme> GaItems { get; set; }
public string SelectedProfile_Ga { get; set; }
public string SelectedPoste { get; set; }
public string PostePrecedentSelected { get; set; }
public string PosteSuivantSelected { get; set; }
public string Position { get; set; }
public string Nbr_Passage { get; set; }
public List<Gamme> ListG = new List<Gamme>();
}
gesttion .ascx:
<% using (Html.BeginForm("Save", "Anouar")) { %>
<%: Html.ValidationSummary(true) %>
<fieldset class="parametrage">
<legend>Gestion de Gamme</legend>
<div><%:Html.Label("Poste :")%><%: Html.DropDownListFor(model => model.SelectedPoste, Model.PostesItems)%></div>
<div><%:Html.Label("Nombre de Passage :")%><%: Html.EditorFor(model=>model.Nbr_Passage)%></div><div class="editor-field"> <%: Html.ValidationMessageFor(model => model.Nbr_Passage)%></div>
<div><%:Html.Label("Position :")%><%: Html.EditorFor(model=>model.Position)%></div>
<div><%:Html.Label("Poste Précédent :")%><%: Html.DropDownListFor(model => model.PostePrecedentSelected, Model.PostesItems)%></div>
<div><%:Html.Label("Poste Suivant :")%><%: Html.DropDownListFor(model => model.PosteSuivantSelected, Model.PostesItems)%></div>
<div><input type="submit" value="Enregistrer" id="btnSave" /></div>
</fieldset>
...
问题是因为FlowViewModel
不是数据库中的实体,而是ViewModel。因此,当您尝试在数据库中查询FlowViewModel.Find...
时,它没有返回任何内容,因为它没有映射到数据库表。
您可能想要从其他表(如Gamme
)中获取各种信息(您正在回写)。您应该从其他数据库实体填充FlowViewModel
,然后传递到视图中。
那么,你想从Profile_GaItems
和Gammes
数据库实体填充做这样的事情:
public ActionResult Update(string id)
{
FlowViewModel flv = new FlowViewModel();
flv.Profile_GaItems = db.Profile_GaItems.ToList();
flv.GaItems = db.Gammes.ToList();
return View(flv);
}