DataGrid中的DataGridCheckBoxColumn用法 ..

<my:DataGridCheckBoxColumn Header="选中" x:Name="checkBox" IsReadOnly="False" CanUserResize="False" Width="35" />

 

 private void btnDeleteNote_Click(object sender, RoutedEventArgs e)
        {
            for (int i = 0; i < this.dgvNotesManage.Items.Count; i++)
            {
                var cntr = dgvNotesManage.ItemContainerGenerator.ContainerFromIndex(i);
                DataGridRow ObjROw = (DataGridRow)cntr;
                if (ObjROw != null)
                {
                    FrameworkElement objElement = dgvNotesManage.Columns[0].GetCellContent(ObjROw);
                    if (objElement != null)
                    {
                        if (objElement.GetType().ToString().EndsWith("CheckBox"))
                        {
                            System.Windows.Controls.CheckBox objChk = (System.Windows.Controls.CheckBox)objElement;
                            if (objChk.IsChecked == true)
                            {
                                //if (System.Windows.MessageBox.Show("确认删除此公告?", "确认公告删除", MessageBoxButton.YesNo) == MessageBoxResult.Yes)
                                //{
                                string noteId = ((DataRowView)this.dgvNotesManage.Items[i])["NoteId"].ToString();
                                string sql = string.Format("DELETE  FROM OODBS_NoteUser WHERE NoteId='{0}'", noteId);
                                bool flag2 = new CommunicationShare.Proxy.ProxyClient().DeleteNoteObject(sql);
                                sql = string.Format("DELETE  FROM OODBS_Notes WHERE NoteId='{0}'", noteId);
                                bool flag1 = new CommunicationShare.Proxy.ProxyClient().DeleteNote(sql);
                            }
                        }
                    }
                }
            }
            BindNoteManage();
        }

//单击某行即选中那行的CheckBox

        private void dgvNotesManage_SelectionChanged(object sender, SelectionChangedEventArgs e)
        {
            var cntr = dgvNotesManage.ItemContainerGenerator.ContainerFromIndex(dgvNotesManage.SelectedIndex);
            DataGridRow ObjROw = (DataGridRow)cntr;
            if (ObjROw != null)
            {
                FrameworkElement objElement = dgvNotesManage.Columns[0].GetCellContent(ObjROw);
                if (objElement != null)
                {
                    if (objElement.GetType().ToString().EndsWith("CheckBox"))
                    {
                        System.Windows.Controls.CheckBox objChk = (System.Windows.Controls.CheckBox)objElement;
                        if (objChk.IsChecked == true)
                        {
                            objChk.IsChecked = false;
                        }
                        else
                            objChk.IsChecked = true;
                    }
                }
            }
        }
View Code

 

转载于:https://www.cnblogs.com/jason-wang/p/3140344.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
WPF DataGrid是一种用于显示数据的控件,而DataGrid.Columns则是DataGrid的列集合。你可以通过设置DataGrid.Columns的Background属性来改变整个列的背景颜色。 在WPF,你可以使用多种方式来设置DataGrid.Columns的Background属性,包括使用静态资源、绑定属性、使用样式等。以下是一些示例代码: 1. 使用静态资源设置DataGrid.Columns的Background属性: ``` <DataGrid> <DataGrid.Columns> <DataGridTextColumn Header="Column 1" Binding="{Binding Column1}"> <DataGridTextColumn.HeaderStyle> <Style TargetType="DataGridColumnHeader"> <Setter Property="Background" Value="{StaticResource MyBrush}" /> </Style> </DataGridTextColumn.HeaderStyle> </DataGridTextColumn> </DataGrid.Columns> </DataGrid> ``` 2. 使用绑定属性设置DataGrid.Columns的Background属性: ``` <DataGrid> <DataGrid.Columns> <DataGridTextColumn Header="Column 1" Binding="{Binding Column1}"> <DataGridTextColumn.HeaderStyle> <Style TargetType="DataGridColumnHeader"> <Setter Property="Background" Value="{Binding DataContext.Column1HeaderBackground, RelativeSource={RelativeSource AncestorType={x:Type DataGrid}}}" /> </Style> </DataGridTextColumn.HeaderStyle> </DataGridTextColumn> </DataGrid.Columns> </DataGrid> ``` 3. 使用样式设置DataGrid.Columns的Background属性: ``` <DataGrid> <DataGrid.Resources> <Style TargetType="DataGridColumnHeader"> <Setter Property="Background" Value="LightGray" /> </Style> </DataGrid.Resources> <DataGrid.Columns> <DataGridTextColumn Header="Column 1" Binding="{Binding Column1}" /> </DataGrid.Columns> </DataGrid> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值