在我的 ASP.NET MVC 2 (RC) 项目中 - 我使用 AutoMapper 在 Linq to Sql 类(Media)和视图模型(MediaVM)之间进行映射。视图模型有一个 SelectList 属性,用于视图中的下拉菜单。我有一个自定义值解析器来填充数据库中的 SelectList 属性项,但我想知道是否有办法将源模型中的几个值传递到解析器(使用 ConstructedBy 方法?)到 a)定义所选项目和 b ) 从数据库中过滤项目。源对象被传递到自定义解析器 - 但解析器用于具有不同类型源对象的几个不同视图模型,因此宁愿定义从我的映射配置中获取值的位置。这是我的视图模型:
public class MediaVM
{
public bool Active { get; set; }
public string Name { get; set; }
[UIHint("DropDownList")]
[DisplayName("Users")]
public SelectList slUsers { get; private set; }
}
自动映射器映射配置:
Mapper.CreateMap<Media, MediaVM>()
.ForMember(dest => dest.slUsers, opt => opt.ResolveUsing<UsersSelectListResolver>());
能够在 .ForMember 映射子句上做这样的事情会很好:
.ConstructedBy(src => new UsersSelectListResolver(src.UserID, src.FilterVal))
有没有办法做到这一点?