当用户点击行链接按钮控件时,如何获取转发器的项目行ID

时间:2014-08-02 20:24:39

标签: c# asp.net repeater findcontrol

我有一个转发器,嵌套了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时,我想获取该行转发器项的ID,并在另一个aspx页面中显示与该ID相关的PDF文件。

我在itemdatabound事件上写道:

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

        }

如何获得嵌套了html表的转发器的列ID?

1 个答案:

答案 0 :(得分:4)

我认为你没有采取正确的方法来做到这一点。我会选择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);
        }
    }

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

希望这有帮助!