web-dev-qa-db-ja.com

WPFでのネストされた要素のスタイル

たとえば、MenuItemsを含むContextMenuなどのネストされた要素構造があるとします。

<ContextMenu Style="{StaticResource FooMenuStyle}">
    <MenuItem Style="{StaticResource FooMenuItemStyle}"/>
    ...
</ContextMenu>

スタイルまたはテンプレートをContextMenuまたはMenuItem要素に簡単に適用できます。ただし、MenuItemスタイルがMenuスタイルに属している場合、すべてのMenuItem要素に追加するのは非常に面倒で冗長です。

それらを自動的に子要素に適用する方法はありますか?簡単に書けるように:

<ContextMenu Style="{StaticResource FooMenuStyle}">
    <MenuItem/>
    ...
</ContextMenu>

FooMenuStyleがMenuItem要素を含むスタイルを設定できると便利ですが、それは可能ではないようです。

編集:私はItemContainerStyleに気づかず、その意図が一般的な解決策であったため、メニューの例はおそらく誤解を招く可能性があります。 2つの答えに基づいて、2つの解決策を考え出しました。1つは一般的なバリアントで、もう1つはItemContainerStyleなどです。

<Style x:Key="FooMenuItem" TargetType="{x:Type MenuItem}">
    ...
</Style>

<Style x:Key="FooMenu" TargetType="{x:Type ContextMenu}">
    <!-- Variant for specific style attribute -->
    <Setter Property="ItemContainerStyle"
            Value="{StaticResource FooMenuItem}"/>

    <!-- General variant -->
    <Style.Resources>
        <Style TargetType="{x:Type MenuItem}"
               BasedOn="{StaticResource FooMenuItem}"/>
    </Style.Resources>
</Style>

<ContextMenu Style="{StaticResource FooMenu}">
    <MenuItem/>
</ContextMenu>
58
gix
<ContextMenu>
   <ContextMenu.Resources>
      <Style TargetType="{x:Type MenuItem}">
         <!--Setters-->
      </Style>
   </ContextMenu.Resources>
   <MenuItem/>
   <!--Other MenuItems-->
</ContextMenu>

スタイルは、ContextMenu内のすべてのMenuItemオブジェクトに適用されます。

21
Josh G

元の答えを完成させるために、そのような親の中にネストされたスタイルを追加することはより明確であると思います:

<Style x:Key="WindowHeader" TargetType="DockPanel" >
    <Setter Property="Background" Value="AntiqueWhite"></Setter>
    <Style.Resources>
        <Style TargetType="Image">
            <Setter Property="Margin" Value="6"></Setter>
            <Setter Property="Width" Value="36"></Setter>
            <Setter Property="Height" Value="36"></Setter>
        </Style>
        <Style TargetType="TextBlock">
            <Setter Property="TextWrapping" Value="Wrap"></Setter>
        </Style>
    </Style.Resources>
</Style>
135
Juan Calero
<ContextMenu ItemContainerStyle="{StaticResource FooMenuItemStyle}">
    <MenuItem/>
</ContextMenu>
5
Kent Boogaart