Was wird bei der Verwendung wiederverwendbarer Geschäftsobjekte als bewährte Methode beim Erstellen von Ansichtsmodellen angesehen?
Wir verwenden ein Objekt, das wir aufrufen Builder
, um unsere Ansichtsmodelle zu erstellen. Ein Builder für jede logische Ansichtseinheit (Bestellungen, Benutzer usw.), wobei jede Einheit eine Reihe verschiedener Ansichtsmodelle enthalten kann (Bestellungen enthalten Zusammenfassung, Auftragspositionen usw.).
Ein Builder kann Daten durch ein oder mehrere Standardgeschäftsobjekte ziehen, um ein Ansichtsmodell zu erstellen.
Was ist die bessere Vorgehensweise bei der Verwendung von Geschäftsobjekten / -modellen in Ansichtsmodellen?
Ansatz 1
Verwendung von Geschäftsobjekten im Ansichtsmodell zulassen?
//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
}
Ansatz 2
Nehmen Sie nur die erforderlichen Daten aus den Geschäftsobjekten
//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
}
Ich kann die Vor- und Nachteile beider erkennen, aber ich frage mich, ob es einen akzeptierten Ansatz gibt. In Ansatz 1 gibt es keine Duplizierung von Code um die Modelle herum, aber es entsteht eine Abhängigkeit von der Geschäftslogik. In Ansatz 2 verwenden Sie nur die für die Ansicht erforderlichen Daten, duplizieren jedoch den Code um die Modelle.