如何将多个自动生成的字段中的数据从视图发送回控制器

时间:2013-04-25 10:42:31

标签: c# asp.net-mvc razor asp.net-mvc-4

我正在构建一个应用程序,允许用户通过一系列问题并从4个预先确定的选项中选择他们的响应。我面临的问题是如何将数据发送回控制器。我有一个对象Game,其中包含一个属性Questions,而每个问题都包含CodeQuestionAnswer,所有string类型。< / p>

我创建了一个页面,在下拉列表中显示每个问题和答案(一旦我弄清楚如何将其作为单选按钮放置,我将使用它),但我很难过如何发送结果返回给控制器:生成的select代码中的每个HTML元素都具有相同的id,那么如何区分问答关系呢?

是否有更好的替代方法?我已尝试为每个问题使用PartialView,但如果可能的话,我想坚持一页,其中包含一系列问题。

我用来创建当前视图的代码是:

@using (Html.BeginForm("Save", "Game", FormMethod.Post)) {
        foreach (var question in Model.Questions) {
            <div class="question">
                <h4>@vraag.Vraag</h4>
                @Html.DropDownListFor(x => question.Code, new SelectList(question .Answers))
                @Html.HiddenFor(x => question.Code)            
            </div>
        }
        <input type="submit" value="Save" />
    }

我想以一种明确告诉我哪个答案是针对什么问题代码的方式将所有答案发送回我的控制器。

1 个答案:

答案 0 :(得分:1)

您不能使用foreach绑定列表,因为它们的名称字段不会被编入索引(因此模型绑定器不知道如何处理它们)。您需要使用for循环。试试这个:

for (int i = 0; i < Model.Questions.Count; i++) {
        <div class="question">
            <h4>@vraag.Vraag</h4>
            @Html.DropDownListFor(x => x.Questions[i].Code, new SelectList(Model.Questions[i].Answers))
            @Html.HiddenFor(x => x.Questions[i].Code)            
        </div>
    }