如何将 ID 从转发器行传递到嵌套网格视图



问题

如果转发器内有一个网格视图,如何将主键 ID 传递给主键与转发器项模板行相关的网格视图?

我目前正在尝试通过使用包含 PK 和控制参数的隐藏字段来检测它并将其绑定到 gridview 来执行此操作。

当前错误

在控件参数"PK"中找不到控件"hidPK"。

缩写代码

<asp:Repeater ID="rpt" RunAt="Server">
  <ItemTemplate>
    <asp:HiddenField ID="hidPK" runat="server" Value='<%# DataBinder.Eval(Container.DataItem, "PK") %>'/>
    <asp:GridView ID="GV" DataSourceID="sqlSource"></asp:GridView>
  </ItemTemplate>
</asp:Repeater>
<asp:SqlDataSource ID="sqlSource" RunAt="Server" SelectCommand="spPopulateGridview" SelectCommandType="StoredProcedure">
  <SelectParameters>
    <asp:ControlParameter Type="Int32" Name="PK" DefaultValue="0" ControlID="hidPK"/>
  </SelectParameters>
</asp:SqlDataSource>

编辑

Protected Sub rpt_ItemDataBound(Sender As Object, e As RepeaterItemEventArgs) Handles rpt.ItemDataBound
    If e.Item.ItemType = ListItemType.Item Or e.Item.ItemType = ListItemType.AlternatingItem  Then
        Dim gv As GridView = TryCast(e.Item.FindControl("GV"), GridView)    
        gv.DataSource = ds
        gv.DataBind()
    End If
End Sub

您可以尝试在转发器中移动 sqldatasource

<asp:Repeater ID="rpt" RunAt="Server">
  <ItemTemplate>
    <asp:HiddenField ID="hidPK" runat="server" Value='<%# DataBinder.Eval(Container.DataItem, "PK") %>'/>
    <asp:GridView DataSourceID="sqlSource"></asp:GridView>
    <asp:SqlDataSource ID="sqlSource" RunAt="Server" SelectCommand="spPopulateGridview" SelectCommandType="StoredProcedure">
      <SelectParameters>
         <asp:ControlParameter Type="Int32" Name="PK" DefaultValue="0" ControlID="hidPK"/>
      </SelectParameters>
    </asp:SqlDataSource>
  </ItemTemplate>
</asp:Repeater>

最新更新