How Do I Find A ClientId Of Control In A Listview?
This question is very similar to How do I find the Client ID of control within an ASP.NET GridView? However I'm using a listview and a label:
Solution 1:
As far as I can tell, there are two ways to accomplish what you are looking to do. Either use an asp:ImageButton
server control and wire up the onclick
client event using the OnItemDataBound
event, or simply use an <input type="image" />
control and wire up the ClientID
inline. The following example shows both approaches:
<%@ Page Language="C#" AutoEventWireup="true" %>
<!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>OnClick Test</title></head>
<body>
<form id="form1" runat="server">
<div>
<asp:ListView ID="lv1" OnItemDataBound="lv1_ItemDataBound" runat="server">
<ItemTemplate>
<asp:Label ID="label1" Text="<%# Container.DataItem %>" runat="server" />
<asp:ImageButton ID="btn1"
ImageUrl="myimage.jpg"
AlternateText="Show Text"
runat="server" />
<input type="image" src="myimage.jpg" alt="Show Text"
onclick="alert(document.getElementById('<%# Container.FindControl("label1").ClientID %>').innerText);"
/>
<br />
</ItemTemplate>
</asp:ListView>
</div>
</form>
</body>
</html>
<script runat="server">
public void Page_Load(object sender, EventArgs e)
{
if (Page.IsPostBack) return;
lv1.DataSource = new[] {"Manny", "Moe", "Jack"};
lv1.DataBind();
}
protected void lv1_ItemDataBound(object sender, ListViewItemEventArgs e)
{
var label1 = e.Item.FindControl("label1") as Label;
var btn1 = e.Item.FindControl("btn1") as ImageButton;
if (label1 == null || btn1 == null) return;
btn1.Attributes.Add("onclick", "alert(document.getElementById('" + label1.ClientID + "').innerText);");
}
</script>
Post a Comment for "How Do I Find A ClientId Of Control In A Listview?"