zoukankan      html  css  js  c++  java
  • WPF 解决多个TreeViewItem同时触发某事件的简单方法

    原理是:

    因为是双击事件,也就是同时引发了选择事件,TreeViewItem的IsSelected为True.通过触发器设置某个属性为特殊值,然后在CS页面的双击事件方法内判断是否此值即可。

    xaml代码:

    <Grid>
            <TreeView>
                <TreeView.Resources>
                    <Style TargetType="TreeViewItem">
                        <Style.Triggers>
                            <Trigger Property="IsSelected" Value="true">
                                <Setter Property="BorderThickness" Value="1"/>
                            </Trigger>
                        </Style.Triggers>
                    </Style>
                </TreeView.Resources>
                <TreeViewItem Header="AAAAA" MouseDoubleClick="TreeViewItem_MouseDoubleClick">
                    <TreeViewItem Header="bbbbb" MouseDoubleClick="TreeViewItem_MouseDoubleClick">
                        <TreeViewItem  Header="ccc" MouseDoubleClick="TreeViewItem_MouseDoubleClick"/>
                    </TreeViewItem>
                </TreeViewItem>
            </TreeView>
        </Grid>

    cs代码

     private void TreeViewItem_MouseDoubleClick(object sender, MouseButtonEventArgs e)
     {

    TreeViewItem treeviewItem = sender as TreeViewItem; if (treeviewItem.BorderThickness == new Thickness(1)) { MessageBox.Show(treeviewItem.Header.ToString()); treeviewItem.IsSelected = false; //其他代码毫无作用 // e.Handled = true; //treeviewItem.AddHandler(TreeViewItem.MouseDoubleClickEvent, (MouseButtonEventHandler)TreeViewItem_MouseDoubleClick, true); }
    }

    原截图

    现在的效果

    *******************************************

    虽然通过其他方法避免的多次重复,但是为什么会触发,以及是否还有其他解决办法暂时是不知道了。

    看样子还是需要仔细查看资料和查看源代码了。

    不得不说这个真的是好问题啊。

    我原本以为使用AddHandler方法会阻止传播,但是并没有效果(苦笑)。

  • 相关阅读:
    创建型模式(四) 单例模式
    创建型模式(三) 原型模式
    创建型模式(二) 建造者模式
    创建型模式(一) 简单工厂模式、工厂模式与抽象工厂模式
    Django15-分页功能
    Django14-Ajax删除按钮动态效果
    网络day04-配置备份、清除、密码恢复、IOS更新
    网络day03-NTP配置和SMTP配置
    网络day02-设备配置远程登录
    HTML注释
  • 原文地址:https://www.cnblogs.com/T-ARF/p/11788620.html
Copyright © 2011-2022 走看看