有没有办法在数据重复控件中“对齐”列?
IE 目前看起来是这样的:
user1 - colA colB colC colD colE
user2 - colD colE
我希望它看起来像:
user1
-colA
-colB
-colC
-colD
-colE
user1
-colD
-colE
当其他记录可能没有给定列的数据时,我需要为每条记录正确对齐列。
要求需要中继器而不是网格控件。
有任何想法吗?
有没有办法在数据重复控件中“对齐”列?
IE 目前看起来是这样的:
user1 - colA colB colC colD colE
user2 - colD colE
我希望它看起来像:
user1
-colA
-colB
-colC
-colD
-colE
user1
-colD
-colE
当其他记录可能没有给定列的数据时,我需要为每条记录正确对齐列。
要求需要中继器而不是网格控件。
有任何想法吗?
如果您可以访问重复中缺少多少列,则只需将以下内容作为表格标记。我你无权访问这个,你能发布你的数据转发器的源代码以及你要反对的数据源吗?
<td colspan='<%# MissingCount(Contatiner.DataItem) %>'>
我建议不要使用<td>
定义列,而是使用 CSS。
.collink {
width: 20px;
float: left;
height: 20px;
}
和
<td style="padding :0px 0px 0px 0px;">
<div class="collink">
<asp:LinkButton ID="lnkEdit" runat="server" ... />
</div>
</td>
这种方法可以让内容增长而不会实际影响表结构。
<tr class="RadGridItem">
<td width="100">
<asp:Label ID="lblFullName" runat="server"
Text ='<%# DataBinder.Eval(Container.DataItem, "FullName") %>'
ToolTip='<%# "Current Grade: " + DataBinder.Eval(Container.DataItem,"CurrentGrade") + "%" +
" Percent Complete: " + DataBinder.Eval(Container.DataItem,"PercentComplete") + "%" %>' />
</td>
<asp:Repeater ID="rptAssessments" runat="server" DataSource='<%# DataBinder.Eval(Container.DataItem, "EnrollmentAssessments") %>'>
<ItemTemplate>
<td style="padding :0px 0px 0px 0px; width:20px; height: 20px;">
<asp:LinkButton ID="lnkEdit" runat="server"
OnClick="AssessmentClick"
style=' <%# "color:" + this.GetAssessmentColor(Container.DataItem) %>'
ToolTip='<%# DataBinder.Eval(Container.DataItem, "AssessmentName") + Environment.NewLine +
DataBinder.Eval(Container.DataItem, "EnrollmentAssessmentStateName") + "(" +
DataBinder.Eval(Container.DataItem, "PercentGradeDisplay") + "%) " +
GetPointsPossible(Container.DataItem) + " pts possible" %>'
CommandArgument='<%# DataBinder.Eval(Container.DataItem, "EnrollmentAssessmentID") %>'
Text='<%# this.GetAssessmentDisplay(Container.DataItem) %>' />
</td>
</ItemTemplate>
</asp:Repeater>
</tr>
</ItemTemplate>
这是代码。根据用于生成列表的标准,列数将是动态的。
谢谢。