javascript - 如何在 Listview 中找到控件的 ClientId?

标签 javascript asp.net listview findcontrol

这个问题与 How do I find the Client ID of control within an ASP.NET GridView?

但是我使用的是 ListView 和标签:

<ItemTemplate>
     <asp:ImageButton ImageUrl="Resources/info.png" ToolTip="info" OnClientClick="toggle('<%#((label)Container).FindControl( "PresetUploadDescription").ClientID %>');"  ID="Description" runat="server"/>
     <asp:Label ID="UploadDescription"  BorderStyle="Solid" BorderColor="Goldenrod" BorderWidth="1" runat="server" Width="40em" CssClass="sc-Upload-description" Text='<%# Eval("Description") %>'></asp:Label>
....  

我在 findcontrol() 函数中收到“服务器标记格式不正确”...知道为什么吗?我已经尝试了“标签”和“控制”转换...

最佳答案

据我所知,有两种方法可以完成您想要做的事情。要么使用 asp:ImageButton服务器控制并连接 onclick使用 OnItemDataBound 的客户端事件事件,或者简单地使用 <input type="image" />控制并连接 ClientID排队。以下示例展示了这两种方法:

<%@ 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>

关于javascript - 如何在 Listview 中找到控件的 ClientId?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8919052/

相关文章:

javascript - 单链查询 mongodb/mongoose 以获取所有评论

javascript - 如何使用javascript将文本框的内容复制到另一个文本框?

javascript - 带有 null src 的 iframe 内 Javascript 文件的路径

asp.net - Asp Core身份,登录后如何获取userId?

asp.net - URL 中存在 %0A 时的 IIS 7 错误请求响应

java - ScrollView 中的两个 ListView ,出于某种原因忽略了 wrap_content

java - 每 10 篇文章下的 Admob/Appodeal 广告横幅

javascript - 对照另一个数组检查数组项

javascript - 此页面上的脚本可能正忙,或者可能已停止响应。 ASP.net

Android:从自定义 ListView 中单击的按钮获取 ListView 项