Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people, just like you, are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
Solved

Why itemcommand event not fired on datalist?

Posted on 2009-04-08
3
1,573 Views
Last Modified: 2013-12-17
Hi,
I have a simple datalist that binds to a datatable. In the datalist, there is a button. It seems that i can't get this button to fire (when clicked) the itemcommand event on the datalist.

My intention is to use the button to get the item ID selected in the datalist.

Please help.

PS: I'd set the EnableEventValidation="False", as i got the error message when click on the button. See below.

Invalid postback or callback argument.  Event validation is enabled using <pages enableEventValidation="true"/> in configuration or <%@ Page EnableEventValidation="true" %> in a page.  
.aspx.vb
----------
Imports System.Data
 
Partial Class Default5
    Inherits System.Web.UI.Page
 
    Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
 
        'Nothing fancy, just populating the datalist with rows.
        Dim dt As New DataTable
        Dim dr As DataRow
        Dim dc As DataColumn
 
        dc = New DataColumn
        dc.ColumnName = "id"
        dt.Columns.Add(dc)
        dc = New DataColumn
        dc.ColumnName = "name"
        dt.Columns.Add(dc)
 
        dr = dt.NewRow
        dr("id") = 1
        dr("name") = "andy"
        dt.Rows.Add(dr)
 
        dr = dt.NewRow
        dr("id") = 2
        dr("name") = "ethan"
        dt.Rows.Add(dr)
 
        dr = dt.NewRow
        dr("id") = 3
        dr("name") = "Matt"
        dt.Rows.Add(dr)
 
        Datalist1.DataSource = dt
        Datalist1.DataBind()
 
    End Sub
 
    Protected Sub Datalist1_ItemCommand(ByVal source As Object, ByVal e As System.Web.UI.WebControls.DataListCommandEventArgs) Handles Datalist1.ItemCommand
       
 MsgBox("I'd clicked on the datalist button")  '# I"M NOT GETTING TO THIS EVENT ON BUTTON CLICK
 
    End Sub
 
End Class
 
 
.aspx
--------
<%@ Page EnableEventValidation="false" Language="VB" AutoEventWireup="false" CodeFile="Default5.aspx.vb" Inherits="Default5" %>
 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
 
    <asp:DataList ID="Datalist1" runat="server" 
            DataKeyField="id" 
            RepeatColumns = "3">
    <HeaderTemplate>
        <strong>Selection Table</strong>
    </HeaderTemplate>
    <ItemTemplate>
        ID: <%#DataBinder.Eval(Container.DataItem, "id")%>
        <br />
        Name: <%#DataBinder.Eval(Container.DataItem, "name")%>
        <br />
        <asp:Button runat="server" CommandName="getID" Text="Get ID" />
        <br /><br />
    </ItemTemplate>
    </asp:DataList>
    
    </div>
    </form>
</body>
</html>

Open in new window

0
Comment
Question by:tangteng78
  • 2
3 Comments
 
LVL 37

Accepted Solution

by:
samtran0331 earned 500 total points
ID: 24098672
try this:

aspx:
<asp:DataList ID="Datalist1" runat="server" DataKeyField="id" RepeatColumns="3">
<HeaderTemplate>
<strong>Selection Table</strong>
</HeaderTemplate>
<ItemTemplate>
ID:
<%#Eval("id")%>
<br />
Name:
<%#Eval("name")%>
<br />
<asp:Button ID="Button1" runat="server" CommandName="getID" CommandArgument='<%#Eval("id")%>'
Text="Get ID" />
<br />
<br />
</ItemTemplate>
</asp:DataList>


code:
Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
If Not Me.Page.IsPostBack = True Then
'Nothing fancy, just populating the datalist with rows.
Dim dt As New DataTable
Dim dr As DataRow
Dim dc As DataColumn

dc = New DataColumn
dc.ColumnName = "id"
dt.Columns.Add(dc)
dc = New DataColumn
dc.ColumnName = "name"
dt.Columns.Add(dc)

dr = dt.NewRow
dr("id") = 1
dr("name") = "andy"
dt.Rows.Add(dr)

dr = dt.NewRow
dr("id") = 2
dr("name") = "ethan"
dt.Rows.Add(dr)

dr = dt.NewRow
dr("id") = 3
dr("name") = "Matt"
dt.Rows.Add(dr)

Datalist1.DataSource = dt
Datalist1.DataBind()
End If

End Sub

Protected Sub Datalist1_ItemCommand(ByVal source As Object, ByVal e As System.Web.UI.WebControls.DataListCommandEventArgs) Handles Datalist1.ItemCommand
Select Case e.CommandName
Case "getID"
Me.Page.ClientScript.RegisterStartupScript(Me.GetType(), "msg", "alert('ID is: " & e.CommandArgument & "');", True)
End Select
End Sub
0
 
LVL 15

Expert Comment

by:NazoUK
ID: 24098721
You should't call databind on a postback as it will interfere with the event handlers.
0
 
LVL 37

Expert Comment

by:samtran0331
ID: 24098781
I posted a tested and working example...
0

Featured Post

How Do You Stack Up Against Your Peers?

With today’s modern enterprise so dependent on digital infrastructures, the impact of major incidents has increased dramatically. Grab the report now to gain insight into how your organization ranks against your peers and learn best-in-class strategies to resolve incidents.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
C#.NET MSVS 2010 is there some things not allowed in Background Worker DoWork? 27 36
Iteration Help (Asp.net VB) 5 24
exporting html table data 4 27
JSON Deserialize issue 6 26
IntroductionWhile developing web applications, a single page might contain many regions and each region might contain many number of controls with the capability to perform  postback. Many times you might need to perform some action on an ASP.NET po…
Real-time is more about the business, not the technology. In day-to-day life, to make real-time decisions like buying or investing, business needs the latest information(e.g. Gold Rate/Stock Rate). Unlike traditional days, you need not wait for a fe…

839 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question