Cuando se utilizan objetos de negocio reutilizables, ¿qué se considera la mejor práctica al crear modelos de vista?
Usamos un objeto que llamamos Builder
para construir nuestros modelos de vista. Un generador para cada unidad lógica de vistas (pedidos, usuarios, etc.), donde cada unidad puede contener varios modelos de vistas diferentes (los pedidos contienen resumen, líneas de pedido, etc.).
Un constructor puede extraer datos a través de uno o más objetos comerciales estándar para construir un modelo de vista.
¿Qué se considera la mejor práctica cuando se trata de usar objetos / modelos comerciales en modelos de vista?
Enfoque 1
¿Permitir el uso de objetos comerciales en el modelo de vista?
//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
}
Enfoque 2
Tome solo los datos necesarios de los objetos comerciales
//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
}
Puedo ver los beneficios y los inconvenientes de ambos, pero me pregunto si hay un enfoque aceptado. En el enfoque 1, no hay duplicación de código alrededor de los modelos, pero crea una dependencia en la lógica de negocios. En el enfoque 2, solo toma los datos necesarios para la vista, pero duplica el código alrededor de los modelos.