Mapper.Initialize(cfg =>
{
cfg.RecognizeDestinationPrefixes("Cust_");
cfg.CreateMap<A, B>();
});
A a = new A() {FirstName = "Cliff", LastName = "Mayson"};
B b = Mapper.Map<A, B>(a);
//b.Cust_FirstName is "Cliff"
//b.Cust_LastName is "Mayson"
Veya alternatif çalışmaz ben Açıkçası
class A
{
String FirstName { get; set; }
String LastName { get; set; }
}
class B
{
String Cust_FirstName { get; set; }
String Cust_LastName { get; set; }
}
söylüyorlar
Bazen, kaynak/hedef özellikleriniz, adlar eşleşmediği için bir grup özel üye eşlemesi yapmanıza neden olan ortak ön/soneklere sahip olacaktır.) (
public class Source {
public int frmValue { get; set; }
public int frmValue2 { get; set; }
}
public class Dest {
public int Value { get; set; }
public int Value2 { get; set; }
}
Mapper.Initialize(cfg => {
cfg.RecognizePrefix("frm");
cfg.CreateMap<Source, Dest>();
});
Mapper.AssertConfigurationIsValid;: Bu sorunu gidermek için, önceden/postfixes tanıyabilir
Mapper.Initialize(cfg => {
cfg.ClearPrefixes();
cfg.RecognizePrefixes("tmp");
});
Şerefe yöntemleri hem mükemmel çalışır: Eğer önek temizlemek gerekiyorsa AutoMapper öneki tanır Varsayılan olarak , "al". Her iki yöntem de A'dan B'ye gerçek haritaya özgü görünmese de, diğer tüm eşlemelerin A'dan C'ye ( –
@ CliffMayson) etkilenmesine rağmen, bunun çok sorunlu olduğunu düşünmüyorum. Aynı sözleşmeyi izleyen hedef sınıflar. Ayrı konfigürasyonlara sahip olmanız gereken durumlarda, örneğin, aynı iki sınıfı eşleştirmek için farklı mantığa sahip olmanız gereken durumlarda, her zaman kendine özgü 'MappingEngine'leri kendi konfigürasyonlarıyla yaratabilirsiniz. HTH. –