У меня в основном есть RadGrid, а внутри RadGrid есть DetailTable. Теперь DetailTable не расширяется, но когда я отлаживаю событие DetailTableDataBind, я вижу, что для DataSource назначены данные. Если я закомментирую все в DetailTableDataBind, то DetailTable расширится, но, очевидно, не будет иметь никаких данных строки, так как я закомментировал событие. По сути, я хочу, чтобы в DetailTable отображался столбец, который использовался внутри RadGrid, в данном случае это столбец «Комментарий».
Почему, когда я пытаюсь назначить DataSource, DetailTable не расширяется?
Вот несколько фрагментов кода.
ASP-страница
<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;
}
Если есть лучший способ сделать это, пожалуйста, дайте мне знать.