Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/272.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 动态下拉列表_C#_Asp.net Mvc 4_Razor - Fatal编程技术网

C# 动态下拉列表

C# 动态下拉列表,c#,asp.net-mvc-4,razor,C#,Asp.net Mvc 4,Razor,我正在做我的第一个MVC项目,我想看看是否有更好的方法来做到这一点。我很肯定有 我正在建立一个审计应用程序。每个审核都有一个问题列表,每个问题都有一个选项列表可供选择。问题和选项可能会改变。因此,我必须动态地构建问题表和带有问题选项的下拉列表 下面是我如何在控制器中创建SelectList foreach (var r in employeeAuditData.Audit.AuditResults) { ViewData["Result" + r.AuditQuestionID] =

我正在做我的第一个MVC项目,我想看看是否有更好的方法来做到这一点。我很肯定有

我正在建立一个审计应用程序。每个审核都有一个问题列表,每个问题都有一个选项列表可供选择。问题和选项可能会改变。因此,我必须动态地构建问题表和带有问题选项的下拉列表

下面是我如何在控制器中创建SelectList

foreach (var r in employeeAuditData.Audit.AuditResults)
{
    ViewData["Result" + r.AuditQuestionID] =
       new SelectList(r.AuditQuestion.QuestionOptions, "QuestionOptionID", "OptionText", r.QuestionOption);
}
这是我的观点的代码

foreach (var r in Model.Audit.AuditResults.OrderBy(r => r.AuditQuestion.Ordinal).ToList())
{
    <tr>
        <td>@r.AuditQuestion.QuestionText</td>
        <td>@Html.DropDownList("Result" + r.AuditQuestionID, "(Select)")</td>
    </tr>
}
foreach(Model.Audit.AuditResults.OrderBy(r=>r.AuditQuestion.Ordinal.ToList()中的var r)
{
@r、 AuditQuestion.QuestionText
@Html.DropDownList(“结果”+r.AuditQuestionID,”(选择)”)
}

这是可行的,但对ViewData键使用连接似乎是一种很时髦的方法。有更好的方法吗?

制作ViewModel怎么样

class AuditResultSelectList
{
    int QuestionId { get; set;}
    SelectList QuestionOptions { get; set;}
}
然后在控制器中:

List<AuditResultSelectList> list = new List<AuditResultSelectList>();

foreach (var r in employeeAuditData.Audit.AuditResults)
{
    AuditResultSelectList a = new AuditResultSelectList()
    {
        QuestionId = r.AuditQuestionID,
        QuestionOptions = new SelectList(r.AuditQuestion.QuestionOptions, "QuestionOptionID", "OptionText", r.QuestionOption)
    }

    list.Add(a);
}

ViewData["QuestionSelectLists"] = list;
List List=新列表();
foreach(employeeAuditData.Audit.AuditResults中的var r)
{
AuditResultSelectList a=新的AuditResultSelectList()
{
QuestionId=r.AuditQuestionID,
QuestionOptions=新建选择列表(r.AuditQuestion.QuestionOptions、“QuestionOptionID”、“OptionText”、r.QuestionOption)
}
列表.添加(a);
}
ViewData[“QuestionSelectList”]=列表;
然后,您的视图可以使用以下方法拉出列表:

var x = (List<AuditResultSelectList>) ViewData["QuestionSelectLists"];
var x=(List)ViewData[“QuestionSelectList”];

我只需要对视图模型进行一些更改,但这肯定会奏效。谢谢网络陌生人!