如何在 ASP.NET Core MVC 中的 Edit 方法的下拉字段中显示 selectedValue来自数据库

如何解决如何在 ASP.NET Core MVC 中的 Edit 方法的下拉字段中显示 selectedValue来自数据库

在 ASP.NET Core 3.1 MVC 项目的以下代码中,Get 操作方法 Edit (...) 显示邮政编码的下拉列表。似乎认情况下,下拉列表将列表中的第一个邮政编码(即 1301)显示为所选值。

如果我想在下拉列表中显示数据库中选择的值,如何在不创建视图模型的情况下通过操作方法 Edit(...) 实现它?

我有一个相当复杂的数据模型,其中邮政编码和城市是表 Shop 中的成员,但该表通过连接表 ProductShop 与产品存在多对多关系。我是初学者,所以我一直在尝试学习本教程,但到目前为止还没有让我了解。 https://docs.microsoft.com/en-us/aspnet/core/data/ef-mvc/update-related-data?view=aspnetcore-5.0 这是我在控制器中的 Edit get 方法

// GET: Products/Edit/5
public async Task<IActionResult> Edit(int? id) {
        if (id == null) {
            return NotFound();
        }

        var product = await _context.Product
            .Include(p => p.Brand)
            .Include(p => p.Price)
            .Include(p => p.ProductCategory)
                .ThenInclude(p => p.Category)
            .Include(p => p.ProductShop)
                .ThenInclude(ps => ps.Shop)
            .Include(s => s.ProductShop)
                .ThenInclude(ps => ps.Shop)
                    .ThenInclude(s => s.Zip)
            .FirstOrDefaultAsync(m => m.Id == id);

        if (product == null) {
            return NotFound();
        }

        ViewData["BrandId"] = new SelectList(_context.Brand,"Id","BrandName",product.BrandId);

    // this is the method where I want to display zipcodes with the help from viewbag
    ViewData["ZipId"] = new SelectList(_context.Zipcode.ToList(),"Zip",product.ProductShop.FirstOrDefault().Shop.Zip.Id);

    PopulateSelectedCategories(product);
    return View(product);
}

我在视图中的下拉列表:

@model vegetarian_Products.Models.DB.Product
@*@model vegetarian_Products.viewmodels.ProductDetailsVM*@
@{
    ViewData["Title"] = "Edit";
}

<h1>Edit</h1>

<h4>Product</h4>
<hr />
<div class="row">
    <div class="col-md-4">
        <form asp-action="Edit">
//....

                <div class="form-group">
                    <label asp-for="ProductShop.FirstOrDefault().Shop.Zip.Zip" class="control-label"></label>
                    <select asp-for="ProductShop.FirstOrDefault().Shop.Zip.Zip" class="form-control" asp-items="ViewBag.ZipId">  
                        </select>
                    <span asp-validation-for="ProductShop.FirstOrDefault().Shop.Zip.Zip" class="text-danger" />
                </div>

 <div class="form-group">
                    <input type="submit" value="Save" class="btn btn-primary" />
                </div>
            </form>
    </div>
</div>

<div>
    <a class="btn btn-primary" asp-controller="Products" asp-action="Index">Back to List</a>
</div>

@section Scripts {
    @{await Html.RenderPartialAsync("_ValidationScriptsPartial");}
}

邮政编码的模型类:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.ComponentModel.DataAnnotations;

namespace vegetarian_Products.Models.DB {
    public partial class Zipcode {
        public Zipcode() {
            Shop = new HashSet<Shop>();
        }

        public int Id { get; set; }

        [required(ErrorMessage = "Tilføj postnr")]
        [displayName("Postnr")]
        public int Zip { get; set; }
        [displayName("By")]
        public string City { get; set; }

        public virtual ICollection<Shop> Shop { get; set; }

    }
}

运行编辑视图的屏幕截图,并且没有从数据库中选择的值:

EditView running - no selectedValue

表关系模型:

Table-relations

解决方法

在这种情况下,只有在 Product 和 Shop 以 1 对 1 的关系直接相关,或者 Product 与 Shop 以 N 对 1 的关系相关时,选择值才有意义。

由于一个产品可以与许多商店相关,而一个商店又与许多产品相关,因此在任一视图中都有一个具有选定值的选择字段是没有意义的。

如果我正确理解了这个模型,那么您想要显示它的方式是在产品编辑页面中有一个商店列表,在商店编辑页面中有一个产品列表。

因此,我建议您将此列表分解为 Selected List ViewData 和 Unselected List ViewData,而不是将它们全部捆绑在一起,然后使用一种添加和删除项目的方式,从而直观地将它们从一个列表移动到另一个列表。

>

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?