我正在尝试为下拉列表获取不同的值,但是当使用以下语法时,它会返回所有行。
有人可以告诉我如何使用正确的语法获取不同的值集吗?
IEnumerable<SelectListItem> ldidList = _db.TrafficHits.Select(c => new SelectListItem
{
Value = c.Id.ToString(),
Text = c.ldid
}).Distinct();
最佳答案
您当前代码的问题是 Distinct
将为 SelectListItem
使用默认比较器。您将需要提供这样的自定义比较器:-
public class SelectListItemComparer : IEqualityComparer<SelectListItem>
{
public bool Equals(SelectListItem x, SelectListItem y)
{
return x.Text == y.Text && x.Value == y.Value;
}
public int GetHashCode(SelectListItem item)
{
int hashText = item.Text == null ? 0 : item.Text.GetHashCode();
int hashValue = item.Value == null ? 0 : item.Value.GetHashCode();
return hashText ^ hashValue;
}
}
然后你可以像这样使用它:-
IEnumerable<SelectListItem> ldidList = _db.TrafficHits.Select(c => new SelectListItem
{
Value = c.Id.ToString(),
Text = c.ldid
}).Distinct(new SelectListItemComparer());
关于c# - 无法使用 SelectListitem 获取不同的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29988659/