0

我正在使用以下控制器填充年份的下拉列表。我不想手动列出年份,而是想从数据库中检索一个列表。我创建了一个 linq 查询并将年份返回到一个列表中,但我不知道如何将该列表放入正在传递的列表中。

    public JsonResult PopulateYears()
    {
        var list = new object[] { };

        list = new object[] {
            new { value = 2001, name = "2001" },
            new { value = 2002, name = "2002" },
            new { value = 2003, name = "2003" }
        };

        var results = dbBudget.Estimates.Select(o => o.Year).Distinct().ToList();

        foreach (var result in results)
        {
            //How do I create entries for list here?
        }

        return Json(list);
    }
4

1 回答 1

1

你可以像这样创建一个匿名类型

var list = (from x in dbBudget.Estimates.Select(o => o.Year).Distinct()
select new {value=x.Year,name = x.Year});

然后就用你的线

return Json(list);

结果将是

[{"name":"2011","value":"2011"},{"name":"2012","value":"2012"},{"name":"2010","value":"2010"}]
于 2012-08-08T14:43:57.323 回答