Como faço para criar um GridView aninhado obrigado a pais EntityDataSource propriedade de navegação?
Pergunta
<asp:FormView DataSourceId="edsAccounts">
<ItemTemplate>
<asp:TextBox Text='<%# Eval("Email") %>' />
<asp:DataGrid ID="dgReports" DataSource='<%# Eval("Reports") %>'>
</ItemTemplate>
</asp:FormView>
<asp:EntityDataSource ID="edsAccounts" runat="server" ConnectionString="name=Entities" DefaultContainerName="Entities" EntitySetName="Accounts" EntityTypeFilter="Account" Include="Reports" />
Eu quero que os dgReports para começar a trabalhar. Note-se que a caixa de texto de e-mail funciona muito bem.
Solução
Eu, na verdade criado fontes de dados internas separadas, mas eu tenho um outro problema. I não pôde definir a cláusula Onde ID da Entidade do pai.
Observe que o FormView.DataItem não é acessível; é do tipo EntityDataSourceWrapper que é uma classe amigo e inacessível.
Então, eu criei uma função para lidar com isso por reflexo.
Eu acho que é um bug Microsoft, até que corrigi-lo, o seguinte pode ser útil para quem usa controles EntityDataSource aninhadas.
Aqui está:
Module Functions
Public Function GetEntity(Of TEntity As EntityObject)(ByVal entityDataSourceWrapper As Object) As TEntity
If entityDataSourceWrapper Is Nothing Then Return Nothing
Dim type = entityDataSourceWrapper.GetType()
If Not type.FullName = "System.Web.UI.WebControls.EntityDataSourceWrapper" Then Return Nothing
Dim wrapper = type.GetProperty("WrappedEntity", Reflection.BindingFlags.NonPublic Or Reflection.BindingFlags.Instance)
Return DirectCast(wrapper.GetValue(entityDataSourceWrapper, Nothing), TEntity)
End Function
End Module
Agora, no código por trás de eu fazer o seguinte:
Protected Sub fvAccounts_DataBound(ByVal sender As Object, ByVal e As EventArgs) Handles fvAccounts.DataBound
If fvAccounts.CurrentMode <> FormViewMode.ReadOnly Then Exit Sub
Dim account As Account = GetEntity(Of Account)(fvAccounts.DataItem)
If account Is Nothing Then Exit Sub
Dim edsReports As EntityDataSource = fvAccounts.Row.FindControl("edsReports")
edsReports.Where = "it.Account.AccountId = " & account.AccountId
gvReports.DataBind()
End Sub
Observe a hierarquia no modelo:. Conta tem muitos relatórios
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow