• C#中DataGridView控件60招


    1. DataGridView当前的单元格属性取得、变更

    2. DataGridView编辑属性

    3. DataGridView最下面一列新追加行非表示

    4. DataGridView判断当前选中行是否为新追加的行

    5. DataGridView删除行可否设定

    6. DataGridView行列不表示和删除

    7. DataGridView行列宽度高度设置为不能编辑

    8. DataGridView行高列幅自动调整

    9. DataGridView指定行列冻结

    10. DataGridView列顺序变更可否设定

    11. DataGridView行复数选择

    12. DataGridView选择的行、列、单元格取得

    13. DataGridView指定单元格是否表示

    14. DataGridView表头部单元格取得

    15. DataGridView表头部单元格文字列设定

    16. DataGridView选择的部分拷贝至剪贴板

    17. DataGridView粘贴

    18. DataGridView单元格上ToolTip表示设定(鼠标移动到相应单元格上时,弹出说明信息)

    19. 设置DataGridView的行头和文本居中


    1.当前的单元格属性取得、变更

     [C#]

     '当前选中单元的值

     Console.WriteLine(DataGridView1.CurrentCell.Value)

     '当前列的Index值

     Console.WriteLine(DataGridView1.CurrentCell.ColumnIndex)

     '当前单元的行Index值

     Console.WriteLine(DataGridView1.CurrentCell.RowIndex)

     '将控件中(0, 0)处的值,赋给当前单元格.

     DataGridView1.CurrentCell =DataGridView1[0, 0]

    2.DataGridView编辑属性

    全部单元格编辑属性

     [C#]

     'DataGridView1只读属性

     DataGridView1.ReadOnly = True

     指定行列单元格编辑属性

    [C#]
     DataGridView1.Columns[1]ReadOnly = True

     DataGridView1.Rows[2].ReadOnly = True

     DataGridView1[0, 0].ReadOnly = True

     根据条件判断单元格的编辑属性

    下例中column2的值是True的时候,Column1设为可编辑
    [C#]
     代码
     private void DataGridView1_CellBeginEdit(object sender, DataGridViewCellCancelEventArgs e)
       {
           if (this.DataGridView1.Columns[e.ColumnIndex].Name.ToString().Equals("Column2"))
           {
        if (DataGridView1["Column2", e.RowIndex].Value.ToString().ToLower().Equals("true"))
        {
            DataGridView1["Column1", e.RowIndex].ReadOnly = false;
        }
        else
        {
            DataGridView1["Column1", e.RowIndex].ReadOnly = true;
        }
           }
       }


    3.DataGridView最下面一列新追加行非表示
    [C#]
     DataGridView1.AllowUserToAddRows = False


    4.判断当前选中行是否为新追加的行
    [C#]
     if (DataGridView1.CurrentRow.IsNewRow)
     {
      Console.WriteLine("当前行,是新添加的行");
     }
     else
     {
      Console.WriteLine("当前行,不是新添加的行");
     }

    5. DataGridView删除行可否设定

    [C#]

     DataGridView1.AllowUserToDeleteRows = False

    根据条件判断当前行是否要删除

    [C#]

    代码
     private void DataGridView1_UserDeletingRow(object sender, DataGridViewRowCancelEventArgs e)
              {
                  if (MessageBox.Show("确定要删除吗?", "删除确认", MessageBoxButtons.OKCancel, MessageBoxIcon.Question).Equals(System.Windows.Forms.DialogResult.OK))
                  {
     
                  }
                  else
                  {
                      e.Cancel = true;
                  }
              }


    6. DataGridView行列不表示和删除

    行列不表示

    [C#]

     'DataGridView1的第一列不表示

     DataGridView1.Columns[0].Visible = False

     'DataGridView1的第一行不表示

     DataGridView1.Rows[0].Visible = False

    行列表头部分不表示

    [C#]
     DataGridView1.ColumnHeadersVisible = False

     DataGridView1.RowHeadersVisible = False

    指定行列删除

    [C#]
     DataGridView1.Columns.Remove("Column1")

     DataGridView1.Columns.RemoveAt(0)

     DataGridView1.Rows.RemoveAt(0)

    选择的行列删除(多行列)

    [C#]
     'DataGridView1删除选中的行

     foreach (DataGridViewRow r in DataGridView1.SelectedRows)
           {
        if (!r.IsNewRow)
        {
            DataGridView1.Rows.Remove(r);
        }
           }


    7. DataGridView行列宽度高度设置为不能编辑

    [C#]

    'DataGridView1的列的宽设为不能编辑


     DataGridView1.AllowUserToResizeColumns = False

     'DataGridView1的行的高设为不能编辑

     DataGridView1.AllowUserToResizeRows = False

    指定行列宽度高度设置为不能编辑

    [C#]

     'DataGridView1指定列宽度设置为不能编辑

     DataGridView1.Columns[0].Resizable = DataGridViewTriState.False

     'DataGridView1指定行高度设置为不能编辑

     DataGridView1.Rows[0].Resizable = DataGridViewTriState.False

    列幅行高最小值设定

    [C#]

     '列幅最小值设定为100

     DataGridView1.Columns[0].MinimumWidth = 100

     '行高最小值设定为50

     DataGridView1.Rows[0].MinimumHeight = 50

     行列表头部分行高列幅设置为不能编辑

    [C#]

     行列表头部分行高设置为不能编辑 

     DataGridView1.ColumnHeadersHeightSizeMode = DataGridViewColumnHeadersHeightSizeMode.DisableResizing

     行列表头部分列幅设置为能编辑

     DataGridView1.RowHeadersWidthSizeMode = DataGridViewRowHeadersWidthSizeMode.EnableResizing

    8. DataGridView行高列幅自动调整
    [C#]

     根据内容,列幅自动调整

     DataGridView1.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.AllCells

     根据内容,行高自动调整

     DataGridView1.AutoSizeRowsMode = DataGridViewAutoSizeRowsMode.AllCells

     表头部分行高列幅自动调整

    [C#]

     '表头列高自动调整

     DataGridView1.ColumnHeadersHeightSizeMode = DataGridViewColumnHeadersHeightSizeMode.AutoSize

     '表头行幅自动调整

     DataGridView1.RowHeadersWidthSizeMode = DataGridViewRowHeadersWidthSizeMode.AutoSizeToAllHeaders

     指定列自动调整

    [C#]

     '指定列的列幅自动调整

     DataGridView1.Columns[0].AutoSizeMode = DataGridViewAutoSizeColumnMode.DisplayedCells

    9. DataGridView指定行列冻结

    列冻结(当前列以及左侧做所有列)

    [C#]

     'DataGridView1的左侧2列固定

     DataGridView1.Columns[1].Frozen = True

    行冻结(当前行以及上部所有行)

    [C#]

     'DataGridView1的上部2行固定

     DataGridView1.Rows[2].Frozen = True

    指定单元格冻结(单元格所在行上部分所有行,列左侧所有列)

    [C#]

     DataGridView1[0, 0]. Frozen = True

    10. DataGridView列顺序变更可否设定

    [C#]

     'DataGridView1的列的位置设定为允许改变

     DataGridView1.AllowUserToOrderColumns = True

     但是如果列冻结的情况下,冻结的部分不能变更到非冻结的部分。

     变更后列位置取得

    [C#]

     '取得列"Column1"现在的位置

     Console.WriteLine(DataGridView1.Columns["Column1"].DisplayIndex)

     '列"Column1"移动到最前面

     DataGridView1.Columns["Column1"].DisplayIndex = 0

    11. DataGridView行复数选择

    不可选择多行

    [C#]

     'DataGridView1不可选择多行

     DataGridView1.MultiSelect = False

    单元格选择的时候默认为选择整行

    [C#]

    '单元格选择的时候默认为选择整行

     DataGridView1.SelectionMode = DataGridViewSelectionMode.FullRowSelect

    12. DataGridView选择的行、列、单元格取得

    [C#]

    '输出选择的单元格位置

     Console.WriteLine("选择的单元格位置")

     foreach (DataGridViewCell c in DataGridView1.SelectedCells)
     {
           Console.WriteLine(c.ColumnIndex + "," + c.RowIndex);
     }

    '输出选择的行位置

     Console.WriteLine("选择的行位置")

     foreach (DataGridViewRow r in dgvBeforeStep.SelectedRows)
     {
           Console.WriteLine(r.Index);
     }

    ''输出选择的列位置

     foreach (DataGridViewColumn col in dgvBeforeStep.SelectedColumns)
     {
        Console.WriteLine(col.Index);
     }

    指定行、列、单元格取得

    [C#]

     '(0, 0)的选中

     DataGridView1[0, 0].Selected = True

     'Index为1的行选中

     DataGridView1.Rows[1].Selected = True

     'Index为2的列选中

     DataGridView1.Columns[2].Selected = True


    13. DataGridView指定单元格是否表示

    [C#]
     if (DataGridView1 [2,0].Displayed&& DataGridView1 [2,0].Visible)
     {
          DataGridView1.CurrentCell = DataGridView1[2,0];
     }


    14. DataGridView表头部单元格取得

    [C#]
     'DataGridView1第一列表头改变

     DataGridView1.Columns[0].HeaderCell.Value = "第一列"

     'DataGridView1第一行表头改变

     DataGridView1.Rows[0].HeaderCell.Value = "第一行"

     'DataGridView1左上角单元格值改变

     DataGridView1.TopLeftHeaderCell.Value = "左上"

    15. DataGridView表头部单元格文字列设定

    更改列Header表示文字列

    [C#]

     'DataGridView1改变第一列头部单元格文字

     DataGridView1.Columns[0].HeaderText = "第一列"

    更改行Header表示文字列

    [C#]

     'DataGridView1行的头部单元格为序号

     for (int i = 0; i < DataGridView1.Rows.Count-1; i++)
     {
          DataGridView1.Rows[i].HeaderCell.Value=i.ToString();
     }

    '行的宽度自动调节

     DataGridView1.AutoResizeRowHeadersWidth( DataGridViewRowHeadersWidthSizeMode.AutoSizeToAllHeaders)

    最左上Header单元格文字列

    [C#]

    '修改最左上单元格

     DataGridView1.TopLeftHeaderCell.Value = "/"

    16. DataGridView选择的部分拷贝至剪贴板

    拷贝模式设定

    [C#]

     DataGridView1.ClipboardCopyMode = DataGridViewClipboardCopyMode.EnableWithoutHeaderText

    选中部分拷贝

    [C#]
     Clipboard.SetDataObject(DataGridView1.GetClipboardContent())

    17.DataGridView粘贴

    [C#]

    代码
     if (DataGridView1.CurrentCell.Value == null)
     {
          return;
     }
     int insertRowIndex = DataGridView1.CurrentCell.RowIndex;
     string pasteText=Clipboard.GetText();
     if(string.IsNullOrEmpty(pasteText))
     {
          return;
     }
     string[] lines=pasteText.Split('\r');
     bool isHeader=true;
     foreach(string line in lines)
     {   
          if(isHeader)
          {
       isHeader=false;
          }
          else
          {
       string[] vals=line.Split('\t');
       if (vals.Length - 1 != DataGridView1.ColumnCount)
       {
           throw new ApplicationException("列数错误");
       }
       DataGridViewRow row = DataGridView1.Rows[insertRowIndex];
       row.HeaderCell.Value=vals[0];
       for(int i=0;i<row.Cells.Count-1;i++)
       {
           row.Cells[i].Value=vals[(i+1)];
       }
       insertRowIndex+=1;
      }
     }

    18. DataGridView单元格上ToolTip表示设定(鼠标移动到相应单元格上时,弹出说明信息)

    [C#]

    指定单元格

     DataGridView1[0, 0].ToolTipText = "指定单元格"

    指定列

     DataGridView1.Columns[0].ToolTipText = "指定列"

    指定行

     DataGridView1.Rows[0].HeaderCell.ToolTipText = "指定行"

     CellToolTipTextNeeded事件,在多个单元格使用相同的ToolTips的时候,可以用该事件,下例为显示当前单元格的行号和列号

    [C#]

     'CellToolTipTextNeeded事件

     private void DataGridView1_CellToolTipTextNeeded(object sender, DataGridViewCellToolTipTextNeededEventArgs e)
     {
          e.ToolTipText = e.RowIndex.ToString() + "," + e.ColumnIndex.ToString();
     }
     
     19. 设置DataGridView的行头和文本居中
     设置ColumnHeadersDafaultCellStyle属性的Alignment为MiddleCenter(行头居中)
     设置DefalutCellStyle属性的Alignment为MiddleCenter(文本居中)

    例如:

    ServerGrid.DataSource = serverList;
                ServerGrid.Columns[0].HeaderCell.Value = "编码";
                ServerGrid.Columns[1].HeaderCell.Value = "页号";
                ServerGrid.Columns[2].HeaderCell.Value = "控件号";
                ServerGrid.Columns[3].HeaderCell.Value = "名称";
                ServerGrid.ColumnHeadersDefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
                ServerGrid.DefaultCellStyle.Alignment = System.Windows.Forms.DataGridViewContentAlignment.MiddleCenter;

  • 相关阅读:
    Mybatis--->第五节注解完成增删改查
    Mybatis--->新增新功能报错,以前都正常,突然报错
    Mybatis--->limit分页查询
    固定套路--->log4j日志运用-Maven
    Mybatis第三节优化别名--->user
    Mybatis入门第二节--->优化
    Mybatis 报错 java.io.IOException: Could not find resource mybatis-config.xml
    学习Java的第十二天
    学习Java的第十一天
    学习Java的第十天
  • 原文地址:https://www.cnblogs.com/baishiying/p/2643785.html
Copyright © 2020-2023  润新知