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方法会阻止传播,但是并没有效果(苦笑)。

  • 相关阅读:
    mybatis 批量插入时候的一个注意点
    centos7 kubernetes单机安装
    debug 模式缓慢
    那些年,我们误解的 JavaScript 闭包
    maven仓库的配置
    闭包
    docker 搭建自己的github
    docker 搭建小型的node开发环境。
    jquery validate
    使用ueditor中的setContent() 时经常报innerHtml错误(笔记)
  • 原文地址:https://www.cnblogs.com/T-ARF/p/11788620.html
Copyright © 2011-2022 走看看