1

我正在处理这些列表以从组合框中获取与所选项目匹配的项目。

private void InitializaMessageElement()
{
    if (_selectedTransactionWsName != null)
    {
  1. 从此处的下拉列表中获取与所选项目匹配的事务 Web 服务名称 output=TestWS 这是正确的

    var getTranTypeWsName = TransactionTypeVModel
         .GetAllTransactionTypes()
         .FirstOrDefault(transTypes => 
                 transTypes.WsMethodName == _selectedTransactionWsName);
    
  2. 从树节点列表中循环 wsnames 列表。在这里,它给了我所有正确的节点。

    var wsNameList = MessageElementVModel
         .GetAllTreeNodes().Select(ame => 
                 ame.Children).ToList();//. == getTranTypeWsName.WsMethodName);
    
  3. 在 wsNameList 中找到 getTranTypeWsName.WsMethodName。这是我遇到问题的地方:

       var msgElementList = MessageElementVModel.GetAllTreeNodes()
                                                     .Select(ame =>   ame.Children).Where(c =>
                                                         {
                                                             c.Where(d =>     getTranTypeWsName != null && d.Name == getTranTypeWsName.WsMethodName);
                                                             return false;
                                                         });
    

我的 MsgElement 列表:

    var _msgElementList = new ObservableCollection<MessageElementViewModel>(msgElementList);
    this.messageElements = _msgElementList;
    NotifyPropertyChanged("MessageElements");
}

在这里它返回错误的数据。它返回所有我有一个未过滤的列表。为什么我的输出不一致?我是 LINQ 的新手。

4

2 回答 2

0

您的这部分代码似乎有问题:

   var msgElementList = wsNameList.SingleOrDefault(x =>
            {
                x.Where(ame => ame.Name == getTranTypeWsName.WsMethodName);
            return true;

            });

您期待一个列表,但您使用了 SingleOrDefault(),它旨在用于检索单个记录。

试试这个,它将检索 msgElementList。无需先获取所有树节点并将其存储在 wsNameList 中:

// Assumed that Name is a property of Children
    var msgElementList = MessageElementVModel.GetAllTreeNodes()
        .Select(ame => ame.Children).Where(c => c.Name == getTranTypeWsName.WsMethodName).ToList();
于 2013-06-17T03:26:05.273 回答
0

这是一个解决方案:

var msgElementList = wsNameList.SelectMany(x => x.Where(ame => getTranTypeWsName != null && ame.Name == getTranTypeWsName.WsMethodName)).ToList();

于 2013-06-18T12:23:26.723 回答