1

我正在尝试转换一组匿名对象,其中每个对象如下所示:

new {type="internal",title="Linktitle",target="_blank",link="http://www.google.se"}

我已经声明了一个类“链接”,匿名对象应该被投射到该类

class Link{
    public string type {get;set;}
    public string target {get;set;}
    public string title {get;set;}
    public string link {get;set;}
}

现在我正在尝试投射对象,就像这样

List<Link> links = Model.relatedLinks.Select(l => new Link{type=l.type,target=l.target,title=l.title,link=l.link}).ToList();

然后我得到错误

Cannot use a lambda expression as an argument to a dynamically dispatched operation without first casting it to a delegate or expression tree type

我发现this page on how to cast anonymous objects,但我也是这样做的。还是我错过了什么?

4

1 回答 1

7

如果relatedLinks它本身是一个动态值,你会遇到两个问题:

  • 已经报告的 lambda 表达式部分
  • 不能对动态值调用扩展方法(作为扩展方法)。这会影响SelectToList方法。

您可以通过转换 lambda 表达式来解决第一个问题。您可以通过直接调用来解决第二个问题Enumerable.Select

// Note: don't use var here. We need the implicit conversion from
// dynamic
IEnumerable<Link> query = Enumerable.Select(Model.relatedLinks, 
                              (Func<dynamic, Link>) (l => new Link { 
                                                            type = l.type,
                                                            target = l.target,
                                                            title = l.title,
                                                            link = l.link } );
var links = query.ToList();

或者为了格式化:

Func<dynamic, Link> projection = l => new Link { 
                                        type = l.type,
                                        target = l.target,
                                        title = l.title,
                                        link = l.link };
IEnumerable<Link> query = Enumerable.Select(Model.relatedLinks, projection);
var links = query.ToList();

如果Model.relatedLinks已经IEnumerable<dynamic>(或类似的东西),那么您可以Select改为作为扩展方法调用 - 但您仍然需要有一个强类型的委托。因此,例如,后一个版本将变为:

Func<dynamic, Link> projection = l => new Link { 
                                        type = l.type,
                                        target = l.target,
                                        title = l.title,
                                        link = l.link };
IEnumerable<Link> query = Model.relatedLinks.Select(projection);
var links = query.ToList();
于 2013-01-13T15:57:46.837 回答