FrameworkElement.GetTemplateChild(String) メソッド


インスタンス化された ControlTemplate のビジュアル ツリー内にある名前付き要素を返します。Returns the named element in the visual tree of an instantiated ControlTemplate.

protected public:
 System::Windows::DependencyObject ^ GetTemplateChild(System::String ^ childName);
protected internal System.Windows.DependencyObject GetTemplateChild (string childName);
member this.GetTemplateChild : string -> System.Windows.DependencyObject
Protected Friend Function GetTemplateChild (childName As String) As DependencyObject



検索する子の名前。Name of the child to find.



要求された要素。The requested element. 要求した名前の要素が存在しない場合は null になります。May be null if no element of the requested name exists.


WPF のテンプレートには、自己完結型の名前スコープがあります。Templates in WPF have a self-contained namescope. これは、テンプレートが再使用されるためです。また、1つのコントロールの複数のインスタンスがテンプレートをインスタンス化している場合、テンプレートで定義されているすべての名前は一意のままにできません。This is because templates are re-used, and any name defined in a template cannot remain unique when multiple instances of a control each instantiate its template. メソッドを呼び出し GetTemplateChild て、インスタンス化された後にテンプレートから取得したオブジェクトへの参照を返します。Call the GetTemplateChild method to return references to objects that come from the template after it is instantiated. メソッドを使用して FrameworkElement.FindName テンプレートから項目を検索することはできません FrameworkElement.FindName 。これは、がより一般的なスコープで動作し、 ControlTemplate 適用後にクラス自体とインスタンス化されたテンプレートの間に接続がないためです。You cannot use the FrameworkElement.FindName method to find items from templates because FrameworkElement.FindName acts in a more general scope, and there is no connection between the ControlTemplate class itself and the instantiated template once it is applied.

FrameworkTemplate.FindName は、このメソッドと同じ機能を提供します。FrameworkTemplate.FindName supplies the same function as this method. FrameworkTemplate.FindName は protected ではなくパブリックです。また、要素内のテンプレートにアクセスしてその中の名前付き項目を検索できるようにする正しい名前スコープの考慮事項を使用します。FrameworkTemplate.FindName is public instead of protected, and it uses correct name-scoping considerations that allow it to access the template within an element and find named items within it. FrameworkTemplate.FindName親コントロールの外部にある要素を取得する必要がある場合は、を使用します。Use FrameworkTemplate.FindName when you need to get an element outside of its parent control.