ListView中的MVC 5 Dropdownlist(IEnumerable of Viewmodel)

时间:2015-03-09 14:54:29

标签: c# asp.net asp.net-mvc view viewmodel

我正在制作一个学校项目,我在我看来陷入了一个下拉列表。所以这是我的ViewModel:

using System;
using System.Collections.Generic;
using System.Linq;
using Klimatogrammen.Models.Domain;

namespace Klimatogrammen.ViewModels
{
    public class VraagViewModel
    {
        public String Question { get; private set; }
        public String Code { get; private set; }
        public List<double> Answers { get; private set; }

        public VraagViewModel(Parameter temp, Klimatogram klim)
        {
            Question = temp.Naam;
            Code = temp.Code;
            Answers = temp.GeefMogelijkeAntwoorden(klim).ToList();
        }

    }
}

相关的视图

@model IEnumerable<Klimatogrammen.ViewModels.VraagViewModel>

<table class="table">
    <tr>
        <th>
            @Html.DisplayNameFor(model => model.Question)
        </th>
    <th>
        @Html.DisplayNameFor(model => model.Answers)
    </th>
       @Html.DropDownListFor(Model) 

@foreach (var item in Model) {
    <tr>
        <td>
            @Html.DisplayFor(modelItem => item.Question)
        </td>
        <td>
            @Html.DropDownListFor(new SelectList(item.Answers))
        </td>

    </tr>

}

</table>

所以我希望有一个双打列表作为问题的答案。每个问题都有自己的具体答案,我想在每个问题旁边显示它们的可能性。

我尝试了一些东西,但我找不到解决方案(从选择列表到选择项目等,但我没有价值或文字,我只想显示双打)。此外,我的观点必须保持IEnumerable(我有我的理由)

任何人都可以对此有所了解吗?

2 个答案:

答案 0 :(得分:2)

为了做到这一点,我建议你将一个IEnumerable的SelectListItem传递给DropDown。因此,为模型添加另一个属性。

...
public double Answer { get; set;}
...

然后将您的double集合转换为SelectListItem

的集合
var collection = Answers.Select(a => new SelectListItem() {Text = a.ToString(), Value = a.ToString()});

然后,一旦您使用下面的帮助程序,您将被排序,您的Model.Answer将具有正确的值

@Html.DropDownListFor(model => model.Answer, Model.Answers)

进一步的工作

我建议制作一个Enumerable扩展程序,它可以接收一些更复杂的对象,然后为您提供选择列表

public static IEnumerable<SelectListItem> ToSelectList<T>(this IEnumerable<T> enumerable) where T : ISelectList
{
    var list = enumerable.ToList();
    if (list.Any())
    {
        return list.Select(l => new SelectListItem() { Text = l.Name, Value = l.Id.ToString() });
        // We can use an interface to define that any type that 
        //has 2 properties (Name and Id) can be converted into a select list.

    }
    return Enumerable.Empty<SelectListItem>();
}

public interface ISelectList
{
    string Name { get; set; }
    int Id { get; set; }
}

如果你想在下次使用一个很棒的衬垫,你可以使用它:

var list = new SelectList(Answers.Select(x=>new KeyValuePair<string,string>(x.ToString(),x.ToString())), "Key", "Value");

答案 1 :(得分:0)

我实际上能够自己修复它(和我的一个朋友一起)。

这是我的观点目前包含的内容:

@model IEnumerable<Klimatogrammen.ViewModels.VraagViewModel>
@{
    Layout = null;
}

<script src="@Url.Content("~/Scripts/jquery.validate.min.js")"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")"></script>
@using (Html.BeginForm("Vraag", "Vraag"))
{
    @Html.ValidationSummary(true)
    <table class="table">
        <tr>
        <th>
            @Html.DisplayNameFor(model => model.Vraag)
        </th>
        <th>
            @Html.DisplayNameFor(model => model.Antwoorden)
        </th>

        @foreach (var item in Model)
        {
            <tr>
                <td>
                    @Html.DisplayFor(modelItem => item.Vraag)
                </td>
                <td>

                    @Html.DropDownListFor(p => item.Antwoord, item.test, "--- Kies een antwoord ---")
                    @Html.ValidationMessageFor(m => item.Antwoord)

                </td>
            </tr>
        }
    </table>

    <div style="text-align:center;"><input type="submit" value="Controleer uw vragen" class="btn btn-default" /></div>
}

item.test包含我的模型中生成的SelectListItem列表。 这样我就得到了我的下拉框!谢谢大家的帮助;)

现在唯一的问题是我的验证消息,如果我没有填写任何内容,我会得到消息,我应该为每个盒子输入一些东西。但是当我填写1时,当我点击我的按钮时,我会转发。 (如果我找到了一个选项,我也会在这里添加它)