Quando si utilizzano oggetti business riutilizzabili, quali sono le migliori pratiche per la creazione di modelli di vista?
Usiamo un oggetto che chiamiamo Builder
per costruire i nostri modelli di vista. Un costruttore per ogni unità logica di viste (ordini, utenti, ecc.), In cui ciascuna unità può contenere un numero di diversi modelli di vista (gli ordini contengono un riepilogo, righe ordine ecc.).
Un builder può estrarre i dati attraverso uno o più oggetti business standard al fine di costruire un modello di vista.
Qual è la pratica migliore quando si tratta di utilizzare oggetti / modelli di business nei modelli di vista?
Approccio 1
Consentire l'uso di oggetti business nel modello di visualizzazione?
//Business object in some library
public class Order
{
public int OrderNum;
public int NumOrderLines;
//...
}
//Order builder in website
public class OrderBuilder
{
public OrderSummary BuildSummaryForOrder(int OrderNum)
{
Some.Business.Logic.Order obOrder = Some.Business.Logic.GetOrder(OrderNum);
//Any exception handling, additional logic, or whatever
OrderSummary obModel = new OrderSummary();
obModel.Order = obOrder;
return obModel;
}
}
//View model
public class OrderSummary
{
public Some.Business.Logic.Order Order;
//Other methods for additional logic based on the order
//and other properties
}
Approccio 2
Prendi solo i dati necessari dagli oggetti business
//Business object in some library
public class Order
{
public int OrderNum;
public int NumOrderLines;
//...
}
//Order builder in website
public class OrderBuilder
{
public OrderSummary BuildSummaryForOrder(int OrderNum)
{
Some.Business.Logic.Order obOrder = Some.Business.Logic.GetOrder(OrderNum);
//Any exception handling, additional logic, or whatever
OrderSummary obModel = new OrderSummary()
{
OrderNum = obOrder.OrderNum,
NumOrderLnes = obOrder.NumOrderLines,
}
return obModel;
}
}
//View model
public class OrderSummary
{
public int OrderNum;
public int NumOrderLines
//Other methods for additional logic based on the order
//and other properties
}
Posso vedere i vantaggi e gli svantaggi di entrambi, ma mi chiedo se esiste un approccio accettato? Nell'approccio 1, non c'è duplicazione di codice attorno ai modelli, ma crea una dipendenza dalla logica aziendale. Nell'approccio 2, si prendono solo i dati necessari per la vista, ma si duplica il codice attorno ai modelli.