WPF ListBoxItem DataTempldate command 执行问题

今天用到MVVM,在listboxItem中做command处理。因为是要获取数据,修改ListBox模板,但是发现command无法正确执行,写在Item中可以正确执行。

网上也遇到类似问题,但是没有对应的解决办法。最后由@WaitingEver 给予解决。

主要用到RelativeSource,RelativeSource属性可以根据相对于目标的关系指向源对象。通常用于目标对象和源对象不在同一个标记块中,当创建控件模板和数据模板会出现这种情况。用到RelativeSource访问顶级ListBox控件去读取相应的属性。

 

出错代码:

<ListBox.ItemTemplate>

         <DataTemplate>

                <Image Margin="5" Source="{Binding}" Width="140" Height="90" Stretch="Fill">

                     <i:Interaction.Triggers>

                           <i:EventTrigger EventName="MouseEnter"> 

                  <i:InvokeCommandAction Command="{Binding ChangeBackGround}" CommandParameter="" /> 
                </i:EventTrigger>
            </i:Interaction.Triggers>
          </Image>
      </DataTemplate>
</ListBox.ItemTemplate>

 

修正后代码:

<ListBox.ItemTemplate>

                            <DataTemplate>

                                <Image Margin="5" Source="{Binding}" Width="140" Height="90" Stretch="Fill">

                                    <i:Interaction.Triggers>

                                        <i:EventTrigger EventName="MouseEnter">

                                            <i:InvokeCommandAction Command="{Binding Path=DataContext.ChangeBackGround,RelativeSource={RelativeSource Mode=FindAncestor,AncestorType=ListBox}}" CommandParameter="" />

                                        </i:EventTrigger>

                                    </i:Interaction.Triggers>

                                </Image>

                            </DataTemplate>

                        </ListBox.ItemTemplate>

 

 

你可能感兴趣的:(command)