当用户单击行链接按钮控件时,如何获取重复器的项目行id

本文关键字:获取 id 项目 何获取 链接 单击 用户 按钮 控件 | 更新日期: 2023-09-27 18:16:19

我有一个重复器,嵌套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>

当用户单击linkbutton时,我想要获得repeater项目的行ID,并将在另一个aspx页面中显示与该ID相关的PDF文件。

我写的itemdataboundevent:

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

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

当用户单击行链接按钮控件时,如何获取重复器的项目行id

我认为你没有按照正确的方法去做。我会选择Repeater的ItemCommand事件的好处来做这件事。

下面的代码可能对你有帮助:

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属性来识别用户期望的操作。还有commandparameter,用于将所需的数据对象传递给服务器。

使用Repeater的OnItemCommand而不是ItemDataBound事件。并编写如下代码;

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

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

希望这对你有帮助!