C# 选择MVC.net核心中链接到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

我试图学习MVC.NETCore,我需要填充一个combobox并将combobox的ID保存到数据库中

我的控制器中有以下代码:

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);
}