C# 选择MVC.net核心中链接到ID的组合框
我试图学习MVC.NETCore,我需要填充一个combobox并将combobox的ID保存到数据库中 我的控制器中有以下代码:C# 选择MVC.net核心中链接到ID的组合框,c#,model-view-controller,asp.net-core-3.1,C#,Model View Controller,Asp.net Core 3.1,我试图学习MVC.NETCore,我需要填充一个combobox并将combobox的ID保存到数据库中 我的控制器中有以下代码: ViewBag.Categories = new List<SelectListItem> { new SelectListItem{ Text="history", Value="1"}, new SelectListItem
ViewBag.Categories = new List<SelectListItem>
{
new SelectListItem{ Text="history", Value="1"},
new SelectListItem{ Text="literature", Value="2"},
};
public IActionResult Upsert(int? id)
{
ViewBag.Categories = new List<SelectListItem>
{
new SelectListItem{ Text="history", Value="1"},
new SelectListItem{ Text="literature", Value="2"},
};
Book = new Book();
if (id == null)
{
//create
return View(Book);
}
//update
Book = _db.Books.FirstOrDefault(u => u.Id == id);
if (Book == null)
{
return NotFound();
}
return View(Book);
}
[HttpPost]
[ValidateAntiForgeryToken]
public IActionResult Upsert()
{
if (ModelState.IsValid)
{
if (Book.Id == 0)
{
//create
_db.Books.Add(Book);
}
else
{
_db.Books.Update(Book);
}
_db.SaveChanges();
return RedirectToAction("Index");
}
return View(Book);
}
把帖子改成这个。您无法从页面获取已发布的详细信息
[HttpPost]
[ValidateAntiForgeryToken]
public IActionResult Upsert(BookListMVC.Models.Book model)
{
if (ModelState.IsValid)
{
if (model.Id == 0)
{
//create
_db.Books.Add(model);
}
else
{
_db.Books.Update(model);
}
_db.SaveChanges();
return RedirectToAction("Index");
}
return View(model);
}
ASP.NET是一个web应用程序框架,而不是数据访问库。您发布的内容没有显示任何将数据保存到数据库的尝试,甚至没有显示从数据库读取数据的尝试。请显示此视图的整个视图和控制器。您可以共享将值保存到数据库的代码吗?您是对的,我已更新了问题。您是否可以显示您的书本类?只是一个注释。许多人还建议您不要在视图和控制器之间使用数据库类。这允许我将comboxbox的Id保存在描述处的“IdCategory”字段中?怎样?你能更好地解释一下吗?在这个测试项目中,所有的工作都很好。问题只是如何在字段“IdCategory”中保存combobox的ID索引。我认为组合框实际上传递的是文本,而不是ID。这是我的问题。不确定值是如何传递的,但如果是,那就太好了。您的问题是select元素的名称错误。应该是IdCategory而不是CategoryAdjust,让您知道。它是用于绑定的name属性。如果您不确定,可以使用htmlhelper生成名称和Id。类似于。。。。。。。而不是手动编写。但这可能不是现代的方式。
@model BookListMVC.Models.Book
<br />
<h2 class="text-info">@(Model.Id!=0 ? "Edit" : "Create") Book</h2>
<br />
<div class="border container" style="padding:30px;">
<form method="post">
@if (Model.Id != 0)
{
<input type="hidden" asp-for="Id" />}
<div class="text-danger" asp-validation-summary="ModelOnly"></div>
<div class="form-group row">
<div class="col-3">
<label asp-for="Name"></label>
</div>
<div class="col-6">
<input asp-for="Name" class="form-control" />
<span asp-validation-for="Name" class="text-danger"></span>
</div>
</div>
<div class="form-group row">
<div class="col-3">
<label asp-for="Author"></label>
</div>
<div class="col-6">
<input asp-for="Author" class="form-control" />
<span asp-validation-for="Author" class="text-danger"></span>
</div>
</div>
<div class="form-group row">
<div class="col-3">
<label asp-for="ISBN"></label>
</div>
<div class="col-6">
<input asp-for="ISBN" class="form-control" />
<span asp-validation-for="ISBN" class="text-danger"></span>
</div>
</div>
<div class="form-group row">
<div class="col-3">
<label asp-for="ISBN"></label>
</div>
<div class="col-6">
<input asp-for="ISBN" class="form-control" />
<span asp-validation-for="ISBN" class="text-danger"></span>
</div>
</div>
<div class="form-group row">
<div class="col-3">
<label asp-for="IdCategory">Category</label>
</div>
<div class="col-6">
<select asp-for="IdCategory" name="CategoryId" asp-items="@ViewBag.Categories">
<option>-- select the category --</option>
</select>
<span asp-validation-for="IdCategory" class="text-danger"></span>
</div>
</div>
<div class="form-group row">
<div class="col-3 offset-3">
<button type="submit" class="btn btn-primary form-control">
@(Model.Id != 0 ? "Update" : "Create")
</button>
</div>
<div class="col-3">
<a asp-action="Index" class="btn btn-success form-control">Back to List</a>
</div>
</div>
</form>
</div>
@section Scripts{
<partial name="_ValidationScriptsPartial" />
}
public class Book
{
[Key]
public int Id { get; set; }
[Required]
public string Name { get; set; }
public string Author { get; set; }
public string ISBN { get; set; }
public int IdCategory { get; set; }
}
[HttpPost]
[ValidateAntiForgeryToken]
public IActionResult Upsert(BookListMVC.Models.Book model)
{
if (ModelState.IsValid)
{
if (model.Id == 0)
{
//create
_db.Books.Add(model);
}
else
{
_db.Books.Update(model);
}
_db.SaveChanges();
return RedirectToAction("Index");
}
return View(model);
}