Предположим, у вас есть структура вложенных элементов, например ContextMenu с MenuItems:
<ContextMenu Style="{StaticResource FooMenuStyle}">
<MenuItem Style="{StaticResource FooMenuItemStyle}"/>
...
</ContextMenu>
Вы можете легко применять стили или шаблоны к элементам ContextMenu или MenuItem. Но если стиль MenuItem относится к стилю Menu, его довольно громоздко и избыточно добавлять в каждый элемент MenuItem.
Есть ли способ применить их автоматически к дочерним элементам? Так что вы можете просто написать это:
<ContextMenu Style="{StaticResource FooMenuStyle}">
<MenuItem/>
...
</ContextMenu>
Было бы замечательно, если бы FooMenuStyle мог стилизовать элементы MenuItem, но это не представляется возможным.
Edit: пример меню, вероятно, вводит в заблуждение, так как я не знал о ItemContainerStyle, и намерение было для общего решения. Основываясь на двух ответах, я придумал два решения: один общий вариант и один для 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>