提问人:Mohamoud Abdi 提问时间:4/16/2023 最后编辑:Mohamoud Abdi 更新时间:4/17/2023 访问量:111
如何在 GridView asp.net VB 语言中为按钮制作事件?
how to make event for button in gridview asp.net vb language?
问:
当我尝试单击网格视图中的按钮以更新所选行时出现错误
代码和图像中的错误
Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
If Not Page.IsPostBack Then
Try
Dim con As New SqlConnection
Dim cmd As New SqlCommand
Dim dt As New DataTable()
con.ConnectionString = "Data Source=DESKTOP-L7LKJH5;Initial Catalog=logicist;Integrated Security=True"
con.Open()
cmd.CommandText = "select * from dalabaad where Status= @Status"
cmd.Parameters.AddWithValue("@Status", "Pending".ToString)
cmd.Connection = con
Datagrid1.DataSource = cmd.ExecuteReader
Datagrid1.DataBind()
Catch ex As Exception
MsgBox(ex.Message)
End Try
End If
depart()
End Sub
Protected Sub Datagrid1_click(sender As Object, e As GridViewCommandEventArgs)
' Update button
If (e.CommandName = "Select") Then
Try
Con.ConnectionString = "Data Source=DESKTOP-L7LKJH5;Initial Catalog=logicist;Integrated Security=True"
Dim sqlText = "UPDATE dalabaad SET Status = @Status WHERE Invoice_No = '" + Datagrid1.SelectedIndex + "'"
Using cnConnect = New SqlConnection(Con.ConnectionString)
Using cm = New SqlCommand(sqlText, cnConnect)
cnConnect.Open()
cm.Parameters.Add("@Status", SqlDbType.NVarChar).Value = "Approved".ToString
cm.ExecuteNonQuery()
MsgBox("Updated")
End Using
End Using
Catch ex As Exception
MsgBox(ex.Message)
End Try
End If
End Sub
<asp:GridView ID="Datagrid1" runat="server" AutoGenerateColumns="False" Width="860px" OnRowCommand="Datagrid1_click" >
<Columns>
<asp:BoundField DataField="RefNo" HeaderText="RefNo" ReadOnly="True" />
<asp:BoundField DataField="Invoice_No" HeaderText="Invoice_No" />
<asp:BoundField DataField="Item_Name" HeaderText="ITem Name" />
<asp:BoundField DataField="Quantity" HeaderText="Quantity" />
<asp:BoundField DataField="Department" HeaderText="Department" />
<asp:BoundField DataField="ReceiverName" HeaderText="Receiver Name" />
<asp:BoundField DataField="Date" HeaderText="Date" />
<asp:BoundField DataField="Approval_By" HeaderText="Approval_By" />
<asp:BoundField DataField="Status" HeaderText="Status" />
<asp:TemplateField>
<ItemTemplate>
<asp:Button runat="server" Text="Button" CommandName="Select" ></asp:Button>
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
对象引用未设置为对象的实例。
我曾多次尝试换地方,但对我不起作用
答:
0赞
Albert D. Kallal
4/17/2023
#1
最好将普通 asp.net 按钮放入该网格视图中。
所以,这个:
<asp:Button id="cmdmyupdate" runat="server"
Text="Status Update"
OnClick="cmdmyupdate_Click"
>
</asp:Button>
所以,让 vs 创建点击事件(就像你对任何普通按钮所做的那样,对吧?
因此,在键入时,它看起来像这样:(您需要/想要使用/让 intel-sense 为代码隐藏创建按钮事件)。
好了,现在如果我们翻转到代码隐藏,我们就可以点击按钮了。
所以,现在你的代码可以是这样的:
因此,我们需要从该行获取/获取发票编号。
我们必须使用 .Cells() 集合(从零开始,因此发票编号是第二个,或“1”)。
Protected Sub cmdmyupdate_Click(sender As Object, e As EventArgs)
Dim btn As Button = sender
Dim gvRow As GridViewRow = btn.NamingContainer
Dim sInvoice As String = gvRow.Cells(1).Text
Dim scon As String =
"Data Source=DESKTOP-L7LKJH5;Initial Catalog=logicist;Integrated Security=True"
Dim sqlText As String =
"UPDATE dalabaad SET Status = @Status WHERE Invoice_No = @InvoiceNum"
Using cnConnect = New SqlConnection(scon)
Using cm = New SqlCommand(sqlText, cnConnect)
cnConnect.Open()
cm.Parameters.Add("@Status", SqlDbType.NVarChar).Value = "Approved"
cm.Parameters.Add("@InvoiceNum", SqlDbType.NVarChar).Value = sInvoice
cm.ExecuteNonQuery()
End Using
End Using
End Sub
评论