vb中如何获取datagrid选中行的值?

vb中如何获取datagrid选中行的值?,第1张

先说明datagrid的一些属性,说清楚了,自然解决方法就明了了。

说明:

Bookmark:设置或返回当前的行标签号

DataGrid1.Columns("ProductID").CellText(DataGrid1.Bookmark)

返回当前行中字段为‘ProductID’的值。

在DataGrid被连接到一个数据库后,可能想要监视用户单击了哪一个单元。可以使用RowColChange事件——而不是Click事件。

如;

PrivateSubDataGrid1_RowColChange(LastRowAsVariant,ByValLastColAsInteger)

Debug.Print_DataGrid1.Columns("ProductID").CellValue(DataGrid1.Bookmark)

EndSub

通过这个方法就能获得用户点击的行的某个值。

利用一下方法可以控制datagrid每列的宽度;

DimcAsColumn

Setc=DataGrid1.Columns.Add(DataGrid1.Columns.Count)

Withc

.Visible=True

.Width=1000

.Caption="我的新列"

.DataField=Adodc1.Recordset.Fields("ProductName").Name

.Alignment=dbgRight

EndWith

下面的代码将删除被单击的列。

PrivateSubDataGrid1_HeadClick(ByValColIndexAsInteger)

DataGrid1.Columns.RemoveColIndex

EndSub

(1)DataGridView.CurrentRow属性暴露DataGridView的当前行,即包含用户单击的单元格的行。该属性是一个DataGridViewRow对象。

(2)以这种方式获得的DataGridViewRow对象包含一个 DataBoundItem属性,它暴露绑定到DataGridView的底层数据,负责当前行显示的数据。这个属性是object类型,因为没有限制 DataGridView必须绑定到数据库。然而,绑定到数据集时,该属性实际上是一个DataGridView对象,因此可以将它强制转换为这种类型。

(3)DataGridView类有一个Row属性,用于访问数据集中的数据行。该属性的类型是DataRow,由于使用的类型化数据集定义可以知道实际的行类型,因此可以将它强制转换为适当的类型。这里的类型是FolkDBDataSet2.StoryRow。

(4)通过类型化数据集的行FolkDBDataSet2.StoryRow,可以使 用属性Summary获得Summary列的值。为保持DataGridView的灵活性,必须采用这种方式。例如,如果采用较简单的方式,将不能把 DataGridView绑定到其他数据源。与.NET中的所有东西一样,如果这是个问题,可创建继承DataGridView的类,并提供必要的功能使 这些更容易实现,但这种复杂性可能是不必要的。

DataBounditem:是控件显示底层数据的一个属性,通过访问它可以获取控件的底层数据,类型为 Object

DataRowView:这是一个类,它的Row属性可以获取当前行的数据

可知:

当我们想要获取DataGridView中的选中行时,可以这么干:

[csharp] view plain copy print?

for ( int i = 0i <dataGridView.SelectedRows.Counti++)

{

DataRow dr = (dataGridView.SelectedRows[i].DataBoundItem as DataRowView).Row

}


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/6800804.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-03-28
下一篇2023-03-28

发表评论

登录后才能评论

评论列表(0条)

    保存