从DB文本值中下载MVC中的列表

时间:2015-09-01 15:33:08

标签: c# asp.net-mvc database drop-down-menu

我有下拉列表的问题。我想在选定列表中显示文本,但选择Id。 我如何实现视图?在视图中,我必须将所选数据保存到模型(odbiorca)

控制器:

var odbiorca = dbU.Uczniowie.OrderBy(d => d.Nazwisko).Select(m => m.Nazwisko + " " + m.Imie).ToList(); //return Names
          var odbiorcaId= dbU.Uczniowie.OrderBy(d => d.Id).Select(m => m.Nazwisko + " " + m.Imie).ToList(); //return IDs

          List<SelectListItem> items = new List<SelectListItem>();

            for (int i=0;i<dbU.Uczniowie.Count();i++)
            {
                items.Add(new SelectListItem { Text = odbiorca[i], Value = odbiorcaId[i] }); 
            }

ViewBag.odbiorca = items;

型号:

public class Uwaga
    {
        [Key]
        [Required]
        public string Id { get; set; }
        [Required]
        public string odbiorca { get; set; }
        [Required]
        public  DateTime data { get; set; }

    }

我尝试过这个解决方案,但程序会保存文本,但不会保存值。 @ Html.DropDownList(“odbiorca”,“----”)

2 个答案:

答案 0 :(得分:0)

两个linq语句都返回相同的值。

var odbiorca = dbU.Uczniowie.OrderBy(d => d.Nazwisko).Select(m => m.Nazwisko + " " + m.Imie).ToList(); //return Names
var odbiorcaId= dbU.Uczniowie.OrderBy(d => d.Id).Select(m => m.Nazwisko + " " + m.Imie).ToList(); //return IDs

这两个都返回m.Nazwisko + " " + m.Imie列表,没有Id。

您应该只使用一个查询来获取选择列表

var list = dbU.Uczniowie.Select(a => new {Text= a.Nazwisko + " " + a.Imie, Value = a.Id}).ToList();

ViewBag.odbiorca = list.Select(a => new SelectListItem{ Text = a.Text, Value = a.Value.ToString()});

答案 1 :(得分:0)

尝试这种方法。让我们参加你的模特课:

public class Uwaga
{
    [Key]
    [Required]
    public string Id { get; set; }
    Required]
    public string odbiorca { get; set; }
    [Required]
    public  DateTime data { get; set; }
}

在视图中,您可以使用相同的帮助程序:@Html.DropDownList("odbiorca", "----")

但是,在控制器中,您可以通过SelectList对象设置“id”和“text”列。以控制器中的默认操作为例:

    public ActionResult Index()
    {
        //Creates a example list with multiple "Uwaga" items, 
        //but you might want to pull the data from the database
        List<Uwaga> UwagaList = new List<Uwaga>();
        for (int i = 1; i <= 10; i++)
        {
            Uwaga item = new Uwaga();
            item.Id = i;
            item.odbiorca = "odbiorca " + i;
            UwagaList.Add(item);
        }

        //Create a SelectList object, the first parameter is the list created above.
        //The second parameter is the "id" key and the thirth 
        //parameter is the text you want to display in the dropdown.
        var SelectList = new SelectList(UwagaList, "Id", "odbiorca");

        //Fill the dropdownlist "odbiorca" using ViewData.
        ViewData["odbiorca"] = SelectList;
    }

我希望它有所帮助。