将linq匿名对象传递给函数

本文关键字:函数 对象 linq | 更新日期: 2023-09-27 18:30:13

我的控制器上有一个Linq查询,它将在列表中给我一个对象,我需要将这个对象传递给另一个类中的函数,该函数将使用它。

这是我的Linq查询:

var cursos = (from c in db.Curso
              join cc in db.CursoCategoria on c.cursoCategoriaId equals cc.ID
              where c.ativo == 1 && c.destaque == 1
              select new { ID        = c.ID,
                           nome      = c.nome,
                           imgAbre   = c.imagemAbre,
                           imgFecha  = c.imagemEfeito,
                           cURL      = c.URL,
                           ccURL     = cc.URL,
                           cCor      = cc.cor}).Take(10).ToList();

这就是我如何调用函数:

var objHelper = new HelperController();
siteVM.lstCursosWall = Json(objHelper.MontaWallCurso());

这是我在HelperController中的函数,这个类也是一个Controller,我之所以这样做,是因为我有几个用于该项目的助手函数和ajax方法:

public string MontaWallCurso()
{
     //TODO STUFF       
}

那么,如果我没有类型,我如何传递这个对象呢?

注意:我使用的是一个DAL模型,我使用EF从数据库中创建,不知道这是否有用。

编辑

因此,我更改了方法并创建了一个类来填充和传输数据,但现在我在将linq结果传递给对象时遇到了问题。

var siteVM  = new SiteViewModel();
var cursos  = new List<CursoWall>();
var lCursos = (from c in db.Curso
               join cc in db.CursoCategoria on c.cursoCategoriaId equals cc.ID
               where c.ativo == 1 && c.destaque == 1
               select new { ID        = c.ID,
                            nome      = c.nome,
                            imgAbre   = c.imagemAbre,
                            imgFecha  = c.imagemEfeito,
                            cURL      = c.URL,
                            ccURL     = cc.URL,
                            cCor      = cc.cor}).Take(10).ToList();
cursos.AddRange(lCursos);

类别:

public class CursoWall
{
    public int ID { get; set; }
    public string nome { get; set; }
    public string imgAbre { get; set; }
    public string imgFecha { get; set; }
    public string cURL { get; set; }
    public string ccURL { get; set; }
    public string cCor { get; set; }
}

将linq匿名对象传递给函数

不能。在这种情况下,您需要为DTO定义一个简单的"Poco"类型来进行数据传输。

http://rlacovara.blogspot.nl/2009/03/what-is-difference-between-dto-and-poco.html

如果您愿意牺牲类型安全性,可以使用C#的动态支持。

public string MontaWallCurso(IList<dynamic> cursos) {
    // use dynamic properties or something that takes dynamic arguments
    foreach( dynamic curso in cursos ) {
        curso.SomePropertyYouAreSureExists = 1;
        curso.SomeMethodYouAreSureExists();
    }
}

或者,如果你愿意牺牲类型安全性并处理问题,你可以使用反思。在某些情况下,您可以间接地做到这一点,例如JSON转换器或其他依赖反射的库代码。

public string MontaWallCurso(IList<object> cursos) {
    // use reflection or something that uses reflection itself
    foreach( object curso in cursos ) {
        Type cursoType = curso.GetType();
        cursoType.GetProperty("SomePropertyYouAreSureExists").SetValue( curso, 1 );
        cursoType.GetProperty("SomeMethodYouAreSureExists").Invoke( curso, null );
    }
}

为了澄清,在这些方法中,我唯一可能推荐的是基于库的反射方法(如果适用的话)。