我是 C# 和 MVC 的新手,我是从 PHP 背景进入 Visual Studio 环境的。我正在摸索一点(很多),但到达那里。我需要帮助来理解一些基本概念,这无疑是一项非常笨拙的工作,但帮助我解决这个问题将帮助我理解事情是如何运作的。
我有一个 SQL 数据库,通过添加 ADO.NET 实体类模型连接到 VS2012 Web 项目 (C#)。可以说那端没有问题,自动生成的默认 CRUD 视图也没有问题。
用例:
我想要一个网页,向用户展示从数据库中提取的项目列表。这已经在默认的索引视图中实现了,但我还希望该列表可以在当时和那里进行编辑,而不必为每个单独的项目输入编辑视图。ActionName
因此,我将列表 HTML 更改为表单,并为“更新”提交设置了一个。这也没有问题:
模型:
namespace Library3.DAL {
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
public partial class PrmTbl_Level {
public PrmTbl_Level() {
this.Tbl_Books = new HashSet<Tbl_Book>();
}
[Required]
[Display(Name = "ID")]
public int LevelID { get; set; }
[Required]
[Display(Name = "Description")]
public string LevelDesc { get; set; }
[Required]
[Display(Name = "Entered By")]
public string EnteredBy { get; set; }
public Boolean Active { get; set; }
public virtual ICollection<Tbl_Book> Tbl_Books { get; set; }
}
}
看法:
@model IEnumerable<Library3.DAL.PrmTbl_Level>
@using (Html.BeginForm("Update", "ReaderLevel", FormMethod.Post, new { enctype = "multipart/form-data" }))
{
@Html.AntiForgeryToken()
@Html.ValidationSummary(true)
<fieldset>
<table>
<thead>
<tr>
<th> @Html.DisplayNameFor(model => model.LevelID) </th>
<th> @Html.DisplayNameFor(model => model.LevelDesc) </th>
<th> @Html.DisplayNameFor(model => model.EnteredBy) </th>
<th> @Html.DisplayNameFor(model => model.Active) </th>
</tr>
</thead>
@foreach (var item in Model) {
var thisID = item.LevelID;
var thisDesc = item.LevelDesc;
var thisEnteredBy = item.EnteredBy;
var thisActive = item.Active;
<tr>
<td class="tdsm centered fade"> @thisID </td>
<td> <input type="text" name="@(thisID + ".desc")" value="@thisDesc" /> </td>
<td class="tdmed centered fade"> @thisEnteredBy </td>
<td class="tdsm centered">
@{
if(@thisActive) {
<text><input type="checkbox" name="@(thisID + ".active")" value="true" checked="checked" /></text>
}
else {
<text><input type="checkbox" name="@(thisID + ".active")" value="true" /></text>
}
}
</td>
</tr>
}all of this
</table>
<p>
<input type="submit" value="Update" />
</p>
</fieldset>
}
控制器:
namespace Library3.Controllers {
public class ReaderLevelController : Controller {
private NSSchoolLibraryEntities db = new NSSchoolLibraryEntities();
public ActionResult Index() {
ViewBag.Title = "Reader Levels";
return View(db.PrmTbl_Levels.ToList());
}
[HttpPost, ActionName("Update")]
[ValidateAntiForgeryToken]
public ActionResult Update(FormCollection MyArray) {
(... Process UPDATE submission ...)
db.SaveChanges();
}
}
return RedirectToAction("Index");
}
}
}
现在我想在我的列表顶部放置一个空字段,以便可以创建新条目。这基本上意味着一个视图文件现在将同时满足创建和更新功能。我插入了以下 HTML:
@using (Html.BeginForm("New", "ReaderLevel", FormMethod.Post, new { enctype = "multipart/form-data" }))
{
@Html.AntiForgeryToken()
@Html.ValidationSummary(true)
<fieldset>
<table>
<tr>
<td class="tdsm centered fade">
@Html.EditorFor(model => model.LevelID)
@Html.ValidationMessageFor(model => model.LevelID)</td>
<td><input type="text" name="desc" />
@Html.EditorFor(model => model.LevelDesc)
@Html.ValidationMessageFor(model => model.LevelDesc)</td>
<td class="tdmed centered fade">
@Html.EditorFor(model => model.EnteredBy)
@Html.ValidationMessageFor(model => model.EnteredBy)</td>
<td class="tdsm centered">
@Html.EditorFor(model => model.Active)
@Html.ValidationMessageFor(model => model.Active)</td>
</tr>
</table>
<p>
<input type="submit" value="Create" />
</p>
</fieldset>
}
...问题是这里引用的模型应该是 PrmTbl_Level 类的新实例 - 不使用现有的 IEnumberable 从表中吐出现有数据(至少这就是我认为问题所在!)。
默认的单独创建视图通过@model
(sans IEnumberable) 引用命名空间,并且数据作为单个对象 ( public ActionResult Create(PrmTbl_Level prmtbl_level)
) 返回,然后毫不费力地保存到数据库 ( db.PrmTbl_Levels.Add(prmtbl_level);
) - 我如何使用一个@model
语句实现相同的目标?(ELI5)。所有的帮助——无论是实际的还是所涉及的概念——非常感谢!