Це може бути основним питанням, але цікаво, що я не отримую метод AutoMapper.Mapper.CreateMap.
Чи використовую я неправильний довідник / пакет AutoMapper? Дякую
Відповіді:
Статичну версію CreateMap
методу було припинено в 4.2, а потім видалено з API у версії 5.0. Про це більш детально розповідає Джиммі Богард у цій публікації в блозі .
Нова техніка відображення є нестатичною, наприклад, така (код з посту):
var config = new MapperConfiguration(cfg => {
cfg.CreateMap<Source, Dest>();
});
IMapper mapper = config.CreateMapper();
var source = new Source();
var dest = mapper.Map<Source, Dest>(source);
The type or namespace name 'MapperConfiguration' could not be found (are you missing a using directive or an assembly reference?)
а також те ж саме, IMapper
чи можете ви допомогти мені
Ось як я використовував AutoMapper у своєму коді.
Крок 1: Завантажено AutoMapper через nuget-пакети .
Версія є
<package id="AutoMapper" version="6.1.1" targetFramework="net452" />
Крок 1: Створено клас DTO
public class NotificationDTO
{
public DateTime DateTime { get; private set; }
public NotificationType Type { get; private set; }
public DateTime? OriginalDateTime { get; private set; }
public string OriginalVenue { get; private set; }
public ConcertDTO Concert { get; set; }
}
public class ConcertDTO
{
public int Id { get; set; }
public bool IsCancelled { get; private set; }
public DateTime DateTime { get; set; }
public string Venue { get; set; }
}
Крок 2: Створено клас AutoMapperProfile, який успадковується від Profile
using AutoMapper;
using ConcertHub.DTOs;
namespace ConcertHub.Models
{
public class AutoMapperProfile : Profile
{
public AutoMapperProfile()
{
CreateMap<Concert, ConcertDTO>();
CreateMap<Notification, NotificationDTO>();
}
}
}
Крок 3: Зареєстрований AutoMapperProfile у методі запуску програми у файлі Global.asax
protected void Application_Start()
{
AutoMapper.Mapper.Initialize(cfg => cfg.AddProfile<AutoMapperProfile>());
}
Нарешті, магічний шматок коду в Api Controller
public IEnumerable<NotificationDTO> GetNewNotification()
{
var userId = User.Identity.GetUserId();
var notifications = _dbContext.UserNotifications
.Where(un => un.UserId == userId && !un.IsRead)
.Select(un => un.Notification)
.Include(n => n.Concert)
.ProjectTo<NotificationDTO>()//use Automapper.QueryableExtension namespace
.ToList();
return notifications;
}
Сподіваюся, це допоможе.
Ось як це працює зараз:
Mapper.Initialize(cfg =>
{
cfg.CreateMap<SupervisorEmployee, SupervisorViewModel>()
.ForMember
(dst => dst.Name, src => src.MapFrom<string>(e => SupervisorViewModel.MapName(e)))
.ForMember
(dst => dst.OfficePhone, src => src.MapFrom<string>(e => e.OfficePhone.FormatPhone(e.OfficePhoneIsForeign)))
.ForMember
(dst => dst.HomePhone, src => src.MapFrom<string>(e => e.HomePhone.FormatPhone(e.HomePhoneIsForeign)))
.ForMember
(dst => dst.MobilePhone, src => src.MapFrom<string>(e => e.MobilePhone.FormatPhone(e.MobilePhoneIsForeign)));
});
Я бачу, що ваш клас не успадкував від AutoMapper.Profile
Я зробив це і працював на мене
public class AutoMapperConfig: AutoMapper.Profile