如何在 .Net MVC 中使用 Array 的内容填充 DropDown?

Posted

技术标签:

【中文标题】如何在 .Net MVC 中使用 Array 的内容填充 DropDown?【英文标题】:How can I populate a DropDown with the contents of an Array in .Net MVC? 【发布时间】:2021-11-23 05:16:26 【问题描述】:

这可能非常明显,但我对 MVC(和一般 C#)非常陌生,我就是想不通。

我有一个 viewModel,其中包含有关项目的几位数据,然后使用 @foreach 将其显示在视图上的表格中。

我想设置一个过滤器,以便只显示属于指定项目的数据。我已经通过使用@foreach 为 viewModel 中存在的每个不同的 ProjectName 创建一个新的过滤器按钮,想出了如何使用过滤器按钮来做到这一点:

<div class="btn-group">
    <button type="button" class="btn btn-default btn-filter" data-target="all">All</button>
    @foreach (var item in Model.Select(s => s.ProjectName).Distinct().ToArray())
    
        <button type="button" class="btn btn-default btn-filter" data-target="@item">@item</button>

    
</div>

实际的过滤是用我找到的 Chosen 和 jQuery 完成的,但我不知道如何将数据从创建按钮转移到填充下拉菜单。

我不想用每个可用的 ProjectName 填充 DropDown,因为有数百个,我只想要加载页面时 viewModel 中实际存在的那些。

我在网上找到的所有教程和指南都涉及创建更多 viewModel 和 List 类,如果可能的话我宁愿避免。

我错过了什么?

【问题讨论】:

【参考方案1】:

我想通了!

我尝试使用 html Helpers,但使用 Chosen 您可以在 SELECT 语句中执行此操作:

    <select class="chosen-select" style="width:200px;">
    <option data-target="all">All</option>
    @foreach (var item in Model.Select(s => s.ProjectName).Distinct().ToArray())
     <option data-target="@item">@item</option>
    
    </select>

【讨论】:

以上是关于如何在 .Net MVC 中使用 Array 的内容填充 DropDown?的主要内容,如果未能解决你的问题,请参考以下文章

将字符串数组发布到 .net-core mvc

MVC 基本工具(Visual Studio 的单元测试使用Moq)

如何在 MVC.NET 2 中使用 ReportViewer 2010

如何在 javascript 文件中使用 resx 文件。 .net 核心 3.1 mvc

MVC 44.MVC 基本工具(Visual Studio 的单元测试使用Moq)

如何在 Asp.Net 5 (MVC 6) 中使用实体框架 6.x