DatagridView,Combobox显示格的问题.

answer_java 2008-09-11 09:33:36
DataGridView每一行里有一列为comboBoxColumn.

从数据库表里取出数据...
比如说
学生主表数据. 学生ID,学生,学生所在班级ID,学生其他人息....
班级表 班级ID,班级名称...

学生ID(Text) 学生姓名(Text) 学生所在班级(ComboBox) 学生其他信息(Text)

要求学生所在班在GRIDVIEW里显示为COMBOBOX...可以选择班级更改学生的所在班级..

实现的方法应该怎么做呢?
...全文
105 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
answer_java 2008-09-11
  • 打赏
  • 举报
回复
我现在的代码格式是这样的.
到红的地方就出错了.

INDEX超出范围?
answer_java 2008-09-11
  • 打赏
  • 举报
回复
Public Class Data
Protected clsCommon As einoCommon.Common ' use the einoCommon
Private ws As einoWS.einoWSSoapClient ' use the WebService

Private Sub Data_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
Try
ws = New einoWS.einoWSSoapClient()
clsCommon = New einoCommon.Common()
Dim stSql As String
stSql = "SELECT ClassId,ClassNm FROM B"
Dim dtlData As DataTable
dtlData = ws.GetData(stSql).Tables(0) 'get produce dataset
Dim cell As New DataGridViewComboBoxCell
Dim col As New DataGridViewComboBoxColumn
Dim drw As DataRow
ComboBox1.Items.Clear()
For Each drw In dtlData.Rows
ComboBox1.Items.Add(New ComboItem(drw(1), drw(0)))
cell.Items.Add(New ComboItem(drw(1), drw(0)))
Next
ComboBox1.SelectedIndex = 0
col.CellTemplate = cell
'col.HeaderText = "ClassNm"
col.DataPropertyName = "ClassNm"
DataGridView1.Columns.Insert(DataGridView1.Columns("ClassNm").Index, col)
DataGridView1.Columns.Remove("ClassNm")
col.Name = "ClassNm"
cell.DisplayMember = "Caption"
cell.ValueMember = "Value"
'DataGridView1.Columns.Add(col)
Catch ex As Exception

End Try
End Sub

Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
Dim stSql As String
Dim itRowIdx As Integer

Dim stStuId As String
Dim stStuNm As String
Dim stClassNm As String
Dim cell As New DataGridViewComboBoxCell
DataGridView1.Rows.Clear()
stSql = "SELECT A.StuId, A.StuNm, B.ClassNm,B.ClassId "
stSql &= "FROM "
stSql &= "A INNER JOIN B ON A.ClassId = B.ClassId "
stSql &= "Where B.ClassId = '" & CType(ComboBox1.SelectedItem, ComboItem).Value & "'"
Dim dtlData As DataTable
dtlData = ws.GetData(stSql).Tables(0) 'get UnionMember dataset

If dtlData.Rows.Count <> 0 Then
For itRowIdx = 0 To dtlData.Rows.Count - 1
stStuId = dtlData.Rows(itRowIdx)(0)
stStuNm = dtlData.Rows(itRowIdx)(1)
'stClassNm = dtlData.Rows(itRowIdx)(2)
'DataGridView1.Rows.Add(stStuId, stStuNm)
DataGridView1.Rows(itRowIdx).Cells(3).Value = dtlData.Rows(itRowIdx)(3).ToString
Next
End If
End Sub

Private Sub Button2_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button2.Click
Dim gdr As DataGridViewRow
Dim stId As String
For Each gdr In DataGridView1.Rows
stId = "Value:" & gdr.Cells(3).Value & vbCrLf
stId &= "Caption:" & gdr.Cells(3).FormattedValue
MessageBox.Show(stId)
Next
End Sub
End Class
YI_Yl 2008-09-11
  • 打赏
  • 举报
回复
把学生所在班这列设为combox
他的值指向Table还是Dataset,有点忘记了
对Table还是Dataset赋值就好了
lazyboysqaz 2008-09-11
  • 打赏
  • 举报
回复
GRIDVIEW中列属性有textbox 和combox,自定义列中
vb.net操作DataGridView控件的用法的集合,包括: 1. DataGridView当前的单元属性取得、变更 2. DataGridView编辑属性 3. DataGridView最下面一列新追加行非表示 4. DataGridView判断当前选中行是否为新追加的行 5. DataGridView删除行可否设定 6. DataGridView行列不表示和删除 DataGridView控件用法合集(二) 7. DataGridView行列宽度高度设置为不能编辑 8. DataGridView行高列幅自动调整 9. DataGridView指定行列冻结 10. DataGridView列顺序变更可否设定 11. DataGridView行复数选择 12. DataGridView选择的行、列、单元取得 DataGridView控件用法合集(三) 13. DataGridView指定单元是否表示 14. DataGridView表头部单元取得 15. DataGridView表头部单元文字列设定 16. DataGridView选择的部分拷贝至剪贴板 17.DataGridView粘贴 18. DataGridView单元上ToolTip表示设定(鼠标移动到相应单元上时,弹出说明信息) DataGridView控件用法合集(四) 19. DataGridView中的ContextMenuStrip属性 20. DataGridView指定滚动框位置 21. DataGridView手动追加列 22. DataGridView全体分界线样式设置 23. DataGridView根据单元属性更改显示内容 24. DataGridView新追加行的行高样式设置る 25. DataGridView新追加行单元默认值设置 DataGridView中输入错误数据的处理(五) 26. DataGridView单元数据错误标签表示 27. DataGridView单元内输入值正确性判断 28. DataGridView单元输入错误值事件的捕获 DataGridView控件用法合集(六) 29. DataGridView行排序(点击列表头自动排序的设置) 30. DataGridView自动行排序(新追加值也会自动排序) 31. DataGridView自动行排序禁止情况下的排序 32. DataGridView指定列指定排序 DataGridView控件用法合集(七) 33. DataGridView单元样式设置 34. DataGridView文字表示位置的设定 35. DataGridView单元内文字列换行 36. DataGridView单元DBNull值表示的设定 37. DataGridView单元样式式化 38. DataGridView指定单元颜色设定 39. DataGridView单元文字字体设置 40. DataGridView根据单元值设定单元样式 DataGridView控件用法合集(八) 41. DataGridView设置单元背景颜色 42. DataGridView行样式描画 43. DataGridView显示行号 44. DataGridView焦点所在单元焦点框不显示的设定 DataGridView控件用法合集(九) 45. DataGridView显示选择框CheckBox 46. DataGridView显示下拉框ComboBox 47. DataGridView单击打开下拉框 48. DataGridView显示按钮 49. DataGridView显示链接 50. DataGridView显示图像 DataGridView控件用法合集(十) 51. DataGridView编辑中单元控件取得 52. DataGridView输入自动完成 53. DataGridView单元编辑时键盘KEY事件取得 54. DataGridView下拉框(ComboBox)单元编辑时事件取得 55. DataGridView下拉框(ComboBox)单元允许文字输入设定 DataGridView控件用法合集(十一) 56. DataGridView根据值不同在另一列中显示相应图片 57. DataGridView显示进度条(ProgressBar) 58. DataGridView中添加MaskedTextBox DataGridView控件用法合集(十二) 59. DataGridView中Enter键按下焦点移至旁边的单元 60. DataGridView行集合化(Group)

16,717

社区成员

发帖
与我相关
我的任务
社区描述
VB技术相关讨论,主要为经典vb,即VB6.0
社区管理员
  • VB.NET
  • 水哥阿乐
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧