嗨,大家好,我有一个将数据填充到表格中的视图,我也有这个视图
@model IEnumerable<"Model">
我认为这样的事情
@foreach (var item in Model)
{
<tr>
<td>
@Html.DisplayFor(modelItem => item.Audit_ID)
</td>
//rest of the code
</tr>
}
我的问题是如何在视图中输入一些内容
@model DAL.EODAuditModel
@model IEnumerable<"Model">
因为我想这样做
@using (Html.BeginForm())
{
@Html.ValidationSummary(true)
<fieldset>
<legend>Employee</legend>
<div class="editor-label">
@Html.LabelFor(model => model.Name)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Name)
@Html.ValidationMessageFor(model => model.Name)
</div>
</fieldset>
}
问题是我无法执行此操作,因为我在视图中定义了2 @model,这将引发异常
我想要这个,因为此视图将查看记录并创建新记录。谢谢。
更新2:我根据建议编辑代码
型号代码:
public class EODAuditModel
{
public EODAuditModel()
{
this.ExistingRecords = new List<EODAuditModel>();
}
public int Audit_ID { get; set; }
[Required]
public string Description { get; set; }
[Required]
public string CreatedBy { get; set; }
public DateTime CreatedDate { get; set; }
public List<EODAuditModel> ExistingRecords { get; set; }
}
查看代码:
@foreach (var item in Model.ExistingRecords)
{
<tr>
<td>
@Html.DisplayFor(modelItem => item.Description)
</td>
<td>
@Html.DisplayFor(modelItem => item.CreatedBy)
</td>
</tr>
}
控制器代码:
public ActionResult Index()
{
EODAuditBL eodBl = new EODAuditBL();
List<EODAuditModel> eodModel = eodBl.GetEODAudit.ToList();
return View(eodModel);
}
GetEODAuditCode:
public IEnumerable<EODAuditModel> GetEODAudit
{
}
当我运行程序时,编译正常,但在网页中收到此错误
传递到字典中的模型项的类型为'System.Collections.Generic.List`1 [DAL.EODAuditModel]',但是此字典需要类型为'DAL.EODAuditModel'的模型项。
您可以创建一个同时包含IEnumerable<"Model">
和Name
属性的新模型类。
public class AuditViewModel
{
public AuditViewModel()
{
this.ExistingRecords = new List<EODAuditModel>();
}
public string Name { get; set; }
public List<EODAuditModel> ExistingRecords { get; set; }
}
在您的视图中定义模型,如下所示
@model AuditViewModel
并将foreach
块更改为此
@foreach (var item in Model.ExistingRecords)
{
<tr>
<td>
@Html.DisplayFor(modelItem => item.Audit_ID)
</td>
//rest of the code
</tr>
}
更新
您似乎收到了错误,因为在控制器中您将实例List<DAL.EODAuditModel>
而不是传递DAL.EODAuditModel
给了视图。将您的控制器更改为此
public ActionResult Index()
{
EODAuditBL eodBl = new EODAuditBL();
List<EODAuditModel> auditList = eodBl.GetEODAudit.ToList();
EODAuditModel model = new EODAuditModel();
model.ExistingRecords = auditList;
return View(model);
}
我进行了更改eodModel
以auditList
避免模型与现有记录之间的混淆。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句