右键菜单自由选择DataGrid显示隐藏列

6 篇文章 0 订阅
3 篇文章 0 订阅


在DataGrid使用中,当有很多列时,可能会遇到选择性的显示列,那么该怎么办呢,我是这么做的:


首先让MenuItem绑定DataGrid的所有列,然后将MenuItem的Item模板列改为CheckBox,在让CheckBox的Content绑定MenuItem的Header,让IsChecked绑定列是否显示隐藏(这里有一个Convert转换器),代码如下:


Xaml:

<MenuItem Header="显示隐藏列" ItemsSource="{Binding PlacementTarget.Columns, RelativeSource={RelativeSource AncestorLevel=1, AncestorType={x:Type ContextMenu}, Mode=FindAncestor}}">
                        <MenuItem.ItemTemplate>
                            <DataTemplate>
                                <CheckBox Content="{Binding Header,UpdateSourceTrigger=PropertyChanged}" IsChecked="{Binding Visibility,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged,Converter={StaticResource DataGridColumnVisibilityConvert}}"/>
                            </DataTemplate>
                        </MenuItem.ItemTemplate>

其中DataGridColumnVisibilityConvert转换器在Resource中引用,然后有一个类实现:

<UserControl.Resources>
        <local:DaraGridColumnVisibility x:Key="DataGridColumnVisibilityConvert"/>
    </UserControl.Resources>



CS:

public class DaraGridColumnVisibility : IValueConverter
    {
        public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
        {
            bool flag = false;
            Visibility vis = (Visibility)value;
            switch (vis)
            {
                case Visibility.Hidden:
                    flag = false;
                    break;
                case Visibility.Visible:
                    flag = true;
                    break;
                default:
                    break;
            }
            return flag;
        }

        public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
        {
            bool flag = System.Convert.ToBoolean(value);
            if (flag)
            {
                return Visibility.Visible;
            }
            else
            {
                return Visibility.Hidden;
            }
        }
    }


OK,这样就可以进行自由选择显示列的,是不是很简单!



  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
WPF中,可以通过以下步骤为DataGrid增加右键菜单: 1. 首先,在XAML文件中定义一个ContextMenu,用于作为右键菜单的内容。可以在Window或者UserControl的资源部分定义ContextMenu,例如: ```xaml <Window.Resources> <ContextMenu x:Key="DataGridContextMenu"> <MenuItem Header="编辑" Click="EditMenuItem_Click"/> <MenuItem Header="删除" Click="DeleteMenuItem_Click"/> </ContextMenu> </Window.Resources> ``` 2. 然后,在DataGrid的样式中,使用EventSetter来为DataGrid的PreviewMouseRightButtonDown事件添加处理程序。在处理程序中,将ContextMenu设置为右键菜单,并设置菜单的PlacementTarget为DataGrid,以确保菜单DataGrid关联。例如: ```xaml <DataGrid> <DataGrid.RowStyle> <Style TargetType="DataGridRow"> <EventSetter Event="PreviewMouseRightButtonDown" Handler="DataGridRow_PreviewMouseRightButtonDown"/> </Style> </DataGrid.RowStyle> </DataGrid> ``` 3. 最后,在代码文件中实现事件处理程序,将ContextMenu设置为右键菜单,并将菜单的PlacementTarget设置为DataGrid。例如: ```csharp private void DataGridRow_PreviewMouseRightButtonDown(object sender, MouseButtonEventArgs e) { DataGridRow row = sender as DataGridRow; if (row != null) { DataGrid dataGrid = FindVisualParent<DataGrid>(row); if (dataGrid != null) { ContextMenu contextMenu = dataGrid.Resources["DataGridContextMenu"] as ContextMenu; if (contextMenu != null) { contextMenu.PlacementTarget = dataGrid; contextMenu.IsOpen = true; e.Handled = true; } } } } private static T FindVisualParent<T>(UIElement element) where T : UIElement { UIElement parent = element; while (parent != null) { T foundElement = parent as T; if (foundElement != null) { return foundElement; } parent = VisualTreeHelper.GetParent(parent) as UIElement; } return null; } ``` 这样,当在DataGrid右键点击时,就会显示出定义的右键菜单

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值