テーブルのすべての行を表示するこの関数があり、追加の詳細を表示して表示できます
public ActionResult ModuleList()
{
var modulesList = new IndexModule();
var modules = _db.Modules
.OrderBy(module => module.DateEntered)
.Select(module => new ModuleVM
{
Id = module.Id,
ModuleId = module.ModuleId,
TypeName = module.ModuleType.TypeName,
DateEntered = module.DateEntered
});
modulesList.Modules = modules.ToList();
return View(modulesList);
}
ここで、パラメーターとして渡された Id に基づいて単一の行を選択したいと考えました
public ActionResult Details(long id)
{
var moduleV = _db.Modules
.Select(module => new ModuleVM
{
Id = id,
ModuleId = module.ModuleId,
TypeName = module.ModuleType.TypeName,
KindName = module.ModuleType.ModuleKind.KindName,
DateEntered = module.DateEntered
});
return View(moduleV);//error
}
エラーは言う:Argument type 'System.Linq.Iqueryable<AdminPortal.Areas.Hardware.Models.ModuleVM>' isnot assignable to model type 'AdminPortal.Areas.Hardware.Models.ModuleVM'
私は上記をしようとしましたが、うまくいきません。私のselectステートメントは、行のみを選択しますid
か? 行を選択して詳細を追加し、ビューに表示したいDetails
これはビューで行ったことです
@using BootstrapSupport
@model AdminPortal.Areas.Hardware.Models.ModuleVM
@{
ViewBag.Title = "Details";
Layout = "~/Views/shared/_BootstrapLayout.basic.cshtml";
}
<fieldset>
<legend>Module <small>Details</small></legend>
<dl> <!-- use this class on the dl if you want horizontal styling http://twitter.github.com/bootstrap/base-css.html#typography class="dl-horizontal"-->
<dt>
@Model.Id
</dt>
<dd>
@Html.Display(Model.Id.ToString())
</dd>
<dt>@Model.ModuleId</dt>
<dd>@Html.Display(Model.ModuleId)</dd>
<dt>@Model.TypeName</dt>
<dd>@Html.Display(Model.TypeName)</dd>
<dt>@Model.KindName</dt>
<dd>@Html.Display(Model.KindName)</dd>
<dt>@Model.DateEntered</dt>
<dd>@Html.Display(Model.DateEntered.ToString())</dd>
</dl>
</fieldset>
<p>
@Html.ActionLink("Edit", "Edit", Model.GetIdValue()) |
@Html.ActionLink("Back to List", "ModuleList")