将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; }
}
您不能。在这种情况下,您需要为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 );
}
}
为了澄清,在这些方法中,我唯一可能推荐的是基于库的反射方法(如果适用的话)。