0

这可能很简单,但转换后我看不到数据

public void SearchGrid(int id, ObservableCollection<TestModel> msgField)
{ 
  foreach (var c in msgField)
    DisplayColor = c.Id == id ? Brushes.Blue : Brushes.Black;
}

林克:

Enumerable.FirstOrDefault(msgField.Where(x => x.Id == id), x => { DisplayColor = Brushes.CadetBlue; });
4

1 回答 1

5

一般来说,创建会产生副作用的查询是个坏主意。我个人会将其重写为:

DisplayColor = msgField.Any(x => x.Id == id) ? Brushes.Blue : Brushes.Black;

这会产生我相信您正在尝试生成的输出。它将DisplayColor根据是否存在匹配的“msgField”元素将其设置为蓝色或黑色。

要获得与当前循环代码相同的结果,您可以使用:

if (msgField.Any())
    DisplayColor = msgField.Last().Id == id ? Brushes.Blue : Brushes.Black;

这将产生与循环相同的输出,因为DisplayColor每次迭代都会覆盖循环,因此只有最后一项很重要。

于 2013-06-14T16:26:31.763 回答