gpt4 book ai didi

c# - ASP.NET Mvc 从 EntityContext 获取 List 的最佳方法?

转载 作者:行者123 更新时间:2023-12-02 21:53:55 28 4
gpt4 key购买 nike

我使用 EntityFramework 作为数据访问,在 ASP.NET MVC Web 应用程序中向我的最终用户查看国家/地区的 DropDownList。

实现这一目标并不难,但我很难找到一种好看的方法。

但首先是一些代码:

<td>
@Html.DropDownListFor(x => x.ParentId, repos.GetParents(@Model.ParentId)
</td>

真正代码深处的某个地方:

class dummy
{
public string Text { get; set; }
public int Value { get; set; }
}

private SelectList _parents;
public SelectList Parents
{
get
{
if (_parents == null)
{
var parents = Entities.Instance.Partners.Select(x => new dummy() { Text = x.Name, Value = x.Id }).OrderBy(x => x.Text).ToList();
parents.Insert(0, new dummy());

_parents = new SelectList(parents, "Value", "Text");
}
return _parents;
}
}

public SelectList GetParents(int? parentId)
{
if (parentId != 0 && parentId.HasValue)
{
//setSelected
}
return Parents;
}

正如你所看到的,我创建了一个**虚拟类只是为了复制数据!为什么?因为x.Id.ToString或等效方法在 linq to entity 中不起作用...

仍然有类似 SqlFunctions.Tostring((double)x.ID) 的内容这不是完美的解决方案,但已经足够了。至少直到我看到它把 Id 4 变成了 string像这样:“*lotsofspaces*4”和修剪每个值对我来说太多了,不能被认为是一个好的解决方案。

最漂亮的代码解决方案是这样的:

new SelectList(Entities.Instance.Partners, "Id", "Name");

漂亮不是吗? :)不,这不对!因为它选择来自合作伙伴的整个数据 - 而不仅仅是 ID 和名称列。

所以我的问题是:当我的 valueField 是 int 时,您能告诉我一种干净且美观的方法来从下拉列表中的 EntityFrame 获取我的数据吗?值类型?

最佳答案

new SelectList(Entities.Instance.Partners.Select(o => new { Id = o.Id, Name = o.Name }).ToList(), "Id", "Name");

关于c# - ASP.NET Mvc 从 EntityContext 获取 List<SelectListItem> 的最佳方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18107252/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com