zoukankan      html  css  js  c++  java
  • WPF的DataGrid当SelectionUnit为DataGridSelectionUnit.Cell时RowDetailsVisibilityMode无效问题

    DataGrid当SelectionUnit设置为DataGridSelectionUnit.Cell方式时:
    RowDetailsVisibilityMode无论置为DataGridRowDetailsVisibilityMode.Visible还是/DataGridRowDetailsVisibilityMode.VisibleWhenSelected均无法显示行详细信息(RowDetails)内容。这是DataGrid本身的使用限制,有时我们确实不想整行(FullRow)选择,那么可以使用下面变通的方式使得行详细信息内容显示或隐藏。思路是给DataGrid应用一个数据触发器,将DetailsVisibility属性与实体的IsSelected(实体包含该属性并且实现接口INotifyPropertyChanged)属性进行关联;然后订阅DataGrid的CurrentCellChanged事件,在事件处理方法中设置绑定实体的IsSelected属性就能解决上述问题了。具体见下面代码:

    <DataGrid.RowStyle>
        <Style TargetType="{x:Type DataGridRow}" >
            <Setter Property="DetailsVisibility" Value="Collapsed" />
            <Style.Triggers>
                <DataTrigger Binding="{Binding Path=IsSelected}" Value="true">
                    <Setter Property="DetailsVisibility" Value="Visible" />
                </DataTrigger>
                <DataTrigger Binding="{Binding Path=IsSelected}" Value="false">
                    <Setter Property="DetailsVisibility" Value="Collapsed" />
                </DataTrigger>
            </Style.Triggers>
        </Style>
    </DataGrid.RowStyle>

    事件处理方法如下:

    void dg_CurrentCellChanged(object sender, EventArgs e)
    {
        DataGrid dg = sender as DataGrid;
        RegisterTransaction o = dg.CurrentItem as RegisterTransaction;
        foreach (var item in CheckBook.Register)
        {
            if (item.IsSelected) item.IsSelected = false;
        }
        o.IsSelected = true;
    }
  • 相关阅读:
    node.js前后台交互示例 -- 使用node.js实现用户注册功能
    window对象
    ajax模仿iframe
    判断浏览器是否支持某些新属性---placeholder兼容问题解决
    jQuery简单tab按钮切换
    js函数的解析与执行过程
    js全局的解析与执行过程
    OKR解读
    《富爸爸穷爸爸》读书笔记【2020207-19】
    《金字塔原理》读书笔记【2020111-30】一读+二读
  • 原文地址:https://www.cnblogs.com/chriskwok/p/2654594.html
Copyright © 2011-2022 走看看