По принцип имам RadGrid и вътре в RadGrid има DetailTable. Сега DetailTable не се разширява, но когато отстранявам грешки в събитието DetailTableDataBind, виждам, че има данни, присвоени на DataSource. Ако коментирам всичко в DetailTableDataBind, тогава DetailTable се разширява, но очевидно няма да има данни за ред, тъй като бях коментирал събитието. По принцип искам DetailTable да показва колона, която е била използвана в RadGrid, която в този случай е колоната "Коментар".
Защо, когато се опитам да присвоя DataSource, таблицата с подробности няма да се разшири?
Ето някои фрагменти от код.
Страницата aspx
<telerik:RadAjaxManager ID="RadAjaxManager1" runat="server">
<AjaxSettings>
<telerik:AjaxSetting AjaxControlID="MemberCommentsGrid">
<UpdatedControls>
<telerik:AjaxUpdatedControl ControlID="MemberCommentsGrid" />
</UpdatedControls>
</telerik:AjaxSetting>
</AjaxSettings>
</telerik:RadAjaxManager>
<telerik:RadGrid ID="MemberCommentsGrid" runat="server" AutoGenerateColumns="false"
AllowPaging="true" PageSize="20" ShowStatusBar="true" OnDetailTableDataBind="MemberCommentsGrid_DetailTableDataBind" Skin="WebBlue">
<ClientSettings AllowExpandCollapse="true">
</ClientSettings>
<MasterTableView AllowMultiColumnSorting="true" DataKeyNames="MemberCommentID">
<Columns>
<telerik:GridBoundColumn DataField="MemberCommentID" HeaderText="Comment ID">
</telerik:GridBoundColumn>
<telerik:GridBoundColumn DataField="Comment" HeaderText="Comment Text">
</telerik:GridBoundColumn>
<telerik:GridBoundColumn DataField="DateAdded" HeaderText="Date Added">
</telerik:GridBoundColumn>
<telerik:GridBoundColumn DataField="UserID" HeaderText="Comment Created By">
</telerik:GridBoundColumn>
</Columns>
<DetailTables>
<telerik:GridTableView Name="MemberCommentsGrid" DataKeyNames="MemberCommentID" runat="server" AutoGenerateColumns="false">
<Columns>
<telerik:GridBoundColumn DataField="Comment" HeaderText="Full ID">
</telerik:GridBoundColumn>
<telerik:GridBoundColumn DataField="Comment" HeaderText="Full Comment">
</telerik:GridBoundColumn>
</Columns>
</telerik:GridTableView>
</DetailTables>
</MasterTableView>
</telerik:RadGrid>
Страницата cs
protected void Page_Load(object sender, EventArgs e)
{
#region Getting DataTable data
string memberName = string.Empty;
if (!IsPostBack)
{
if (Request.QueryString["MemName"] != null)
memberName = Request.QueryString["MemName"].ToString();
else
Response.Redirect("../Account/Login.aspx");
using (AcquirerPortal.Data.MemberComments mc = new AcquirerPortal.Data.MemberComments())
{
dtMemberComments = mc.GetMemberComments(Members.GetMemberIDByMemberName(memberName));
}
}
#endregion
MemberCommentsGrid.DataSource = dtMemberComments;
MemberCommentsGrid.DataBind();
}
protected void MemberCommentsGrid_DetailTableDataBind(object source, Telerik.Web.UI.GridDetailTableDataBindEventArgs e)
{
e.DetailTableView.DataSource = e.DetailTableView.ParentItem["Comment"].Text;
}
Ако има по-добър начин да направите това, моля, уведомете ме.