CompositionContainer.Compose(CompositionBatch) Metódus
Definíció
Fontos
Egyes információk olyan, kiadás előtti termékekre vonatkoznak, amelyek a kiadásig még jelentősen módosulhatnak. A Microsoft nem vállal kifejezett vagy törvényi garanciát az itt megjelenő információért.
Hozzáadja vagy eltávolítja a megadott CompositionBatch alkatrészeket a tárolóból, és végrehajtja az összeállítást.
public:
void Compose(System::ComponentModel::Composition::Hosting::CompositionBatch ^ batch);
public void Compose(System.ComponentModel.Composition.Hosting.CompositionBatch batch);
member this.Compose : System.ComponentModel.Composition.Hosting.CompositionBatch -> unit
Public Sub Compose (batch As CompositionBatch)
Paraméterek
- batch
- CompositionBatch
CompositionContainer Az összeállítás során a belefoglalandó módosítások.
Példák
Ebben az egyszerű példában három rész jön létre és ad hozzá a CompositionContainer, és egy rész beolvasva azt mutatja, hogy az összes importálás ki lett töltve. Ez a példa az attribútumos programozási modellt használja.
[Export]
class Part1
{
public String data = "This is the example data!";
}
[Export]
class Part2
{
[Import]
public Part1 data { get; set; }
}
[Export]
class Part3
{
[Import]
public Part2 data { get; set; }
}
class Program
{
static void Main(string[] args)
{
CompositionContainer container = new CompositionContainer();
CompositionBatch batch = new CompositionBatch();
batch.AddPart(AttributedModelServices.CreatePart(new Part1()));
batch.AddPart(AttributedModelServices.CreatePart(new Part2()));
batch.AddPart(AttributedModelServices.CreatePart(new Part3()));
container.Compose(batch);
Part3 _part = container.GetExportedValue<Part3>();
Console.WriteLine(_part.data.data.data);
Console.ReadLine();
}
}
<Export()>
Public Class Part1
Public ReadOnly Property data As String
Get
Return "This is the example data!"
End Get
End Property
End Class
<Export()>
Public Class Part2
<Import()>
Public Property data As Part1
End Class
<Export()>
Public Class Part3
<Import()>
Public Property data As Part2
End Class
Sub Main()
Dim container As New CompositionContainer()
Dim batch As New CompositionBatch()
batch.AddPart(AttributedModelServices.CreatePart(New Part1()))
batch.AddPart(AttributedModelServices.CreatePart(New Part2()))
batch.AddPart(AttributedModelServices.CreatePart(New Part3()))
container.Compose(batch)
Dim _part As Part3
_part = container.GetExportedValue(Of Part3)()
Console.WriteLine(_part.data.data.data)
Console.ReadLine()
End Sub
Megjegyzések
Ez a módszer az alkatrészek közvetlen hozzáadásának vagy eltávolításának elsődleges módja a tárolóból. Az CompositionContainer akarat mindig stabil, álló állapotot tart fenn. Ezért az üres Compose hívás CompositionBatch soha nem szükséges a kompozíció elindításához. Ehelyett hívja meg a metódust Compose , amikor módosítania kell a rendelkezésre álló CompositionContaineralkatrészeket.
A CompositionBatch fájl mindkét hozzáadandó és eltávolítandó alkatrészt tartalmazhat. Az újrabontás csak egyszer történik minden egyes hívásnál Compose.