繁体   English   中英

用户单击行时如何获取转发器的项目行ID

[英]How to get items row id of repeater when user clicks rows linkbutton control

我有一个与HTML表格行嵌套的中继器:

<asp:Repeater ID="Repeater1" runat="server" OnItemDataBound="Repeater1_ItemDataBound">
               <HeaderTemplate>
                   <table id="grid">
                       <thead>
                           <tr>
                               <th>SID</th>
                               <th>Start Date</th>
                               <th>End Date</th>..
                               <th>PDF Text</th>
                           </tr>
                       </thead>
                       <tbody>
          </HeaderTemplate>
          <ItemTemplate>
              <tr>
                  <td><%#DataBinder.Eval(Container.DataItem,"ID") %></td>
                  <td><%#DataBinder.Eval(Container.DataItem,"startDate") %></td>
                  <td><%#DataBinder.Eval(Container.DataItem,"endDate") %></td
                  <td>
                      <asp:LinkButton runat="server" ID="lbtnPDF" Text="PDF Full Text" OnClick="lbtnPDF_Click" />
                  </td>
              </tr>
          </ItemTemplate>
               <FooterTemplate>
                   </tbody>
                   </table>
               </FooterTemplate>
           </asp:Repeater>

当用户单击链接按钮时,我想获取该转发器项目行的ID,并将在另一个aspx页面中显示与该ID相关的PDF文件。

我写了itemdatabound事件:

protected void Repeater1_ItemDataBound(object sender, RepeaterItemEventArgs e)
        {
            LinkButton lnkBtn = (LinkButton)e.Item.FindControl("lbtnPDF");

        }

如何获得与html表嵌套的中继器的列ID?

我认为您没有遵循正确的方法来执行此操作。 我会选择Repeater的ItemCommand Event的好处来做。

以下代码可能对您有帮助:

HTML / ASP.net

   <asp:Repeater ID="Repeater1" DataSourceID="SqlDataSource1" runat="server" OnItemCommand="Repeater1_ItemCommand">
    <ItemTemplate>
        <asp:Button ID="Button1" runat="server" Text='<%#DataBinder.Eval(Container.DataItem,"Username") %>' CommandName="ViewPDF" CommandArgument='<%#DataBinder.Eval(Container.DataItem,"ID") %>' />
    </ItemTemplate>
</asp:Repeater>
<asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString='<%$ ConnectionStrings:myConnString %>' SelectCommand="SELECT * FROM [tblUserAccounts]"></asp:SqlDataSource>

您已经注意到,我在标签中使用了CommandName和CommandArgument属性。 我已经使用CommandName属性来标识用户期望执行的操作。 也是将所需数据对象传递到服务器的CommandArgument。

转到Repeater的OnItemCommand而不是ItemDataBound事件。 并编写如下代码:

 protected void Repeater1_ItemCommand(object source, RepeaterCommandEventArgs e)
    {
        if (e.CommandName == "ViewPDF")
        {
            Response.Redirect("~/MyPDFFiles/" + (string)e.CommandArgument);
        }
    }

现在运行并测试您的应用程序!

希望这可以帮助!

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM