vb.net 在 datagridview 中打开选定的行以在另一种形式中进行编辑

声明:本页面是StackOverFlow热门问题的中英对照翻译,遵循CC BY-SA 4.0协议,如果您需要使用它,必须同样遵循CC BY-SA许可,注明原文地址和作者信息,同时你必须将它归于原作者(不是我):StackOverFlow 原文地址: http://stackoverflow.com/questions/20498027/
Warning: these are provided under cc-by-sa 4.0 license. You are free to use/share it, But you must attribute it to the original authors (not me): StackOverFlow

提示:将鼠标放在中文语句上可以显示对应的英文。显示中英文
时间:2020-09-17 16:05:39  来源:igfitidea点击:

open selected row in datagridview to edit in Another form

vb.netdatagridviewedit

提问by user3077945

I am using vb.net designer to connect to access database . On my Form1 I have a DataGridView And Two Button For Add And Edit I Make Form2 To Add Data Into Database And Worked OK .. Imake Form3 Wiht Same form2 Content Now I need When i selcet row in DataGridView And Clic Edit Button The data of selected row show on form3 for Edit it

我正在使用 vb.net 设计器连接访问数据库。在我的 Form1 上,我有一个 DataGridView 和两个用于添加和编辑的按钮,我让 Form2 将数据添加到数据库中并且工作正常.. Imake Form3 与 form2 内容相同,现在我需要当我在 DataGridView 和 Clic 编辑按钮中选择行时选择的数据在 form3 上显示行以进行编辑

Public Class Form1

Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load
    Me.SalesTableAdapter.Fill(Me.OrdersDataSet.sales)

    Me.DateTimePicker1.Value = Date.Today
End Sub

Private Sub DateTimePicker1_ValueChanged(sender As Object, e As EventArgs) Handles DateTimePicker1.ValueChanged
    SalesBindingSource.Filter = String.Format("date = '{0}'", DateTimePicker1.Value.ToShortDateString())
End Sub

Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
    Form2.Show()
End Sub

Private Sub Button2_Click(sender As Object, e As EventArgs) Handles Button2.Click
    Form3.Show()
End Sub

Private Sub Label1_Click(sender As Object, e As EventArgs) Handles Label1.Click

End Sub

Private Sub SalesDataGridView_CellContentClick(sender As Object, e As DataGridViewCellEventArgs) Handles SalesDataGridView.CellContentClick
End Sub
End Class

回答by Bj?rn-Roger Kringsj?

You need to approach this in a modal/dialog way. You only need one form for both addand edit.

您需要以模式/对话的方式来解决这个问题。您只需要一个表单即可添加编辑

Add/Edit form

添加/编辑表单

Add a parameterized constructor to the form.

向表单添加参数化构造函数。

Public Sub New(row As DataRowView)
    Me.InitializeComponent()
    'Me.ctlAge: NumericUpDown control.
    'Me.ctlBirthday: DateTimePicker control.
    'Me.ctlName: TextBox control.
    If (row Is Nothing) Then
        'Add mode, set default values:
        Me.ctlAge.Value = 0
        Me.ctlBirthday.Value = Date.Now
        Me.ctlName.Text = String.Empty
    Else
        'Edit mode, set current values:
        Me.ctlAge.Value = CDec(row.Item("AGE"))
        Me.ctlBirthday.Value = CDate(row.Item("BIRTHDAY"))
        Me.ctlName.Text = CStr(row.Item("NAME"))
    End If
End Sub

You also need an accept button and a cancel button.

您还需要一个接受按钮和一个取消按钮。

Friend Sub btnAcceptClicked(sender As Object, e As EventArgs) Handles btnAccept.Click
    Me.DialogResult = Windows.Forms.DialogResult.OK
    Me.Close()
End Sub

Friend Sub btnCancelClicked(sender As Object, e As EventArgs) Handles btnCancel.Click
    Me.DialogResult = Windows.Forms.DialogResult.Cancel
    Me.Close()
End Sub

Main form

主要形式

Add method:

添加方法:

Private Sub btnAddClicked(sender As Object, e As EventArgs) Handles btnAdd.Click
    Try
        Using f As New AddOrEditForm(CType(Nothing, DataRowView))
            If (f.ShowDialog() = Windows.Forms.DialogResult.OK) Then

                Dim view As DataView = TryCast(Me.SalesDataGridView.DataSource, DataView)

                If (view Is Nothing) Then
                    Throw New InvalidCastException()
                End If

                Dim viewRow As DataRowView = view.AddNew()

                viewRow.EndEdit()
                viewRow.Item("AGE") = f.ctlAge.Value
                viewRow.Item("BIRTHDAY") = f.ctlBirthday.Value
                viewRow.Item("NAME") = f.ctlName.Text
                viewRow.EndEdit()

            End If
        End Using
    Catch ex As Exception
        MessageBox.Show(ex.Message)
    End Try
End Sub

Edit method:

编辑方法:

Private Sub btnEditClicked(sender As Object, e As EventArgs) Handles btnEdit.Click
    Try

        Me.SalesDataGridView.EndEdit()

        If (Me.SalesDataGridView.SelectedRows.Count > 0) Then

            Dim gridRow As DataGridViewRow = Me.SalesDataGridView.SelectedRows(0)
            Dim viewRow As DataRowView = TryCast(gridRow.DataBoundItem, DataRowView)

            If (viewRow Is Nothing) Then
                Throw New InvalidCastException()
            End If

            Using f As New AddOrEditForm(viewRow)
                If (f.ShowDialog() = Windows.Forms.DialogResult.OK) Then
                    viewRow.BeginEdit()
                    Try
                        viewRow.Item("AGE") = f.ctlAge.Value
                        viewRow.Item("BIRTHDAY") = f.ctlBirthday.Value
                        viewRow.Item("NAME") = f.ctlName.Text
                        viewRow.EndEdit()
                    Catch ex As Exception
                        viewRow.CancelEdit()
                        Throw ex
                    End Try
                End If
            End Using

        End If

    Catch ex As Exception
        MessageBox.Show(ex.Message)
    End Try
End Sub