WinForm DataGridView新增加行

 

1.不显示最下面的新行

通常 DataGridView 的最下面一行是用户新追加的行(行头显示 * )。如果不想让用户新追加行即不想显示该新行,可以将 DataGridView 对象的 AllowUserToAddRows 属性设置为 False。

DataGridView1.AllowUserToAddRows = false;

但是,可以通过程序: DataGridViewRowCollection.Add 为 DataGridView 追加新行。

2. 为生成的新行添加默认值

当用户选择“新行”作为当前行,DataGridView会触发DefaultValuesNeeded事件。在该事件中可以访问新行,并为其生成默认值,为用户输入提供方便。

1
2
3
4
5
6
7
8
9
private  void  dataGridView1_DefaultValuesNeeded( object  sender, DataGridViewRowEventArgs e)
{
     e.Row.Cells[ "Region" ].Value =  "WA" ;
     e.Row.Cells[ "City" ].Value =  "Redmond" ;
     e.Row.Cells[ "PostalCode" ].Value =  "98052-6399" ;
     e.Row.Cells[ "Region" ].Value =  "NA" ;
     e.Row.Cells[ "Country" ].Value =  "USA" ;
     e.Row.Cells[ "CustomerID" ].Value = NewCustomerId();
}

3.在新行中输入数据

用户开始在新行输入数据之前,新行的IsNewRow属性值为true,即第一次触发改行的CellEnter和CellBeginEdit事件中IsNewRow事件为Ture。 一旦用户开始输入,这一行就不再是新行了,DataGridView中会产生一个“新”的新行,看下面示意图:

在添加“新”的新行时,会触发UserAddedRow事件,它的事件处理函数的第二个参数有属性Row,指定了这个“新”的新行。如果用户此时按下Escape键,“新”的新行会被移除,这会触发UserDeletingRow事件,它的事件处理函数的第二个参数的属性Row指定了“新”的新行。

4. 自定义新行的可视化效果

  • 新行是基于RowTemplate模板创建的,如果没有指定它的单元格的样式,它们会采用继承的样式。
  • 新行中单元格的初始值是由每个单元格的DefaultNewRowValue属性决定的。对于DataGridViewImageCell类型的单元格,其初始值为一个占位图片,其它类型的则为null。你可以重 写这个属性以返回自定义值。但也可以在DefaultValuesNeeded事件处理函数中对默认值进行替换,该事件在焦点进入新行时触发。
  • 新行标题的标准图标是箭头或者星号,并没有得到暴露。如果你要自定义这个图标,就需要创 建一个自定义的DataGridViewRowHeaderCell 类。
  • 新行的标题的标准图标使用标题单元格DataGridViewCellStyle的ForeColor属性。注意:如果没有足够的空间,图标就不会再显示。
  • 如果为标题单元格设置了字符串值(通过Value属性),但没有足够的控件同时显示文本和图标,那么图标会被首先截掉。

5. 新行的排序

  • 在非绑定模式下,新行总是添加在DataGridView的最后一行,即使已经对数据排序。用户需要在添加新行后会“自动”再次进行排序,以将新记录放在合适的位置;这种行为方式类似于ListView控件。
  • 在绑定模式或虚拟模式(Virtual Mode)下,如果已对数据排序,那么插入数据时的行为取决于数据模型的实现方式。对于ADO.NET,新加的行会被自动排序至合适的位置。
### 回答1: 要在Winform DataGridView删除,可以使用以下步骤: 1. 获取要删除的的索引或对象。 2. 调用DataGridView.Rows.Remove方法删除。 例如,以下代码删除选定的: ``` if (dataGridView1.SelectedRows.Count > 0) { dataGridView1.Rows.Remove(dataGridView1.SelectedRows[0]); } ``` 或者,以下代码删除指定索引的: ``` dataGridView1.Rows.RemoveAt(2); ``` 请注意,删除时,如果该包含任何关联的数据,您需要确保同时删除这些数据,以避免数据不一致。 ### 回答2: Winform DataGridView(数据表格)是一种非常常用的用户界面控件,通常用于展示和编辑大量数据。在使用DataGridView时,通常需要对数据进增、删、改操作。本文将着重介绍在Winform DataGridView删除的方法。 Winform DataGridView提供了几种方式来删除数据,具体有两种:删除选择的和删除指定的。 1. 删除选择的Winform DataGridView想要删除的,然后在代码调用DataGridView的方法即可: ``` dataGridView1.Rows.Remove(dataGridView1.SelectedRows[0]); ``` 这段代码首先使用了SelectedRows属性来获取当前被选择的,然后调用Rows的Remove()方法,该方法会将数据从DataGridView删除,同时也会从数据源删除该。 2. 删除指定的 如果要删除DataGridView指定的,则需指定该的索引,即调用Rows.RemoveAt()方法: ``` dataGridView1.Rows.RemoveAt(3); ``` 这段代码会删除DataGridView的第4(索引从0开始)。 然而,如果要在Winform DataGridView删除,我们还需要注意以下几点: 1. 不要在foreach循环删除 在C#,如果在foreach循环删除元素会报错。因为当你删除一个元素时,集合的大小发生了变化,此时foreach无法正确地读取集合,所以会出现错误。因此,建议使用for循环,倒序删除元素。 2. 数据源和DataGridView应该同步 删除DataGridView的数据时,应该同步更数据源的数据,否则当重加载数据时,删除的数据会再次出现。删除数据源的数据可以调用相关方法,如DataTable或BindingList的Remove方法。 3. 不要忽略删除的异常 在某些情况下,无法删除DataGridView。例如,如果正在编辑该时,或者该处于锁定状态,则删除操作会引发异常。因此,应该使用try-catch语句处理这些异常。 总的来说,Winform DataGridView删除非常简单,但在实际应用还是有很多需要注意的地方。只有注意这些细节,才能保证程序的稳定性和可靠性。 ### 回答3: WinformDataGridView为我们提供了一种非常方便的方式来展示和编辑数据。 DataGridView控件的删除操作,通常分为两种:一种是从数据源删除该数据所占用的,并同时将DataGridView也删除掉;另一种是只将DataGridView删除掉,而不直接影响数据源的数据。 下面针对这两种情况,给大家详细介绍DataGridView的删除操作: 1. 删除DataGridView,不影响数据源的数据 在DataGridView,删除只需要调用控件的Rows.RemoveAt()方法即可,该方法接收一个int类型的参数,表示要删除的的索引位置。 代码示例: ``` private void btnDelete_Click(object sender, EventArgs e) { if (dgvData.SelectedRows.Count > 0) { dgvData.Rows.RemoveAt(dgvData.SelectedRows[0].Index); } } ``` 2. 删除DataGridView,并从数据源同时删除该数据 删除DataGridView的数据和同时从数据源删除数据,这种情况比第一种情况复杂一些。 当我们对DataGridView的数据进删除操作时,需要注意以下几点: - DataGridView绑定的数据源必须是可编辑的,比如List、DataTable等; - 删除DataGridView后,需要将数据源对应的数据也删除; - 数据源改变后,需要重绑定到DataGridView控件上。 代码示例: ``` private void btnDelete_Click(object sender, EventArgs e) { if (dgvData.SelectedRows.Count > 0) { // 获取当前选数据的索引 int index = dgvData.SelectedRows[0].Index; // 从数据源删除该数据 (dgvData.DataSource as DataTable).Rows.RemoveAt(index); // 刷DataGridView dgvData.DataSource = dgvData.DataSource; } } ``` 以上就是针对WinformDataGridView删除的操作方法,希望能对大家有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值