Solved

Why itemcommand event not fired on datalist?

Posted on 2009-04-08
3
1,604 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
[X]
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
  • 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

More Than Just A Video Library

Train for your certification. Learn the latest DevOps tools. Grow your skillset to do better work.

At Linux Academy, we release new training modules every week so you'll always be up to date on the latest tech.

Question has a verified solution.

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

The ECB site provides FX rates for major currencies since its inception in 1999 in the form of an XML feed. The files have the following format (reducted for brevity) (CODE) There are three files available HERE (http://www.ecb.europa.eu/stats/exch…
If you need to start windows update installation remotely or as a scheduled task you will find this very helpful.
There are cases when e.g. an IT administrator wants to have full access and view into selected mailboxes on Exchange server, directly from his own email account in Outlook or Outlook Web Access. This proves useful when for example administrator want…
In this brief tutorial Pawel from AdRem Software explains how you can quickly find out which services are running on your network, or what are the IP addresses of servers responsible for each service. Software used is freeware NetCrunch Tools (https…

688 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