我有一个使用的 gridview <asp:BoundField DataField="Comments" HeaderText="COMMENTS" />
,我想在填充 gridview 时只显示 Commemnt 列中的前 20 个字符。有没有办法在VB中完成这个?谢谢你。
问问题
2440 次
1 回答
1
一种方法是RowDataBound
在代码隐藏中使用事件:
Protected Sub Gridview1_RowDataBound(sender As Object, e As GridViewRowEventArgs) Handles Gridview1.RowDataBound
Select Case e.Row.RowType
Case DataControlRowType.DataRow
' assuming the comments column is the first column '
If e.Row.Cells(0).Text.Length > 20 Then
e.Row.Cells(0).Text = e.Row.Cells(0).Text.Substring(0, 20)
End If
End Select
End Sub
请注意,您只能使用 以这种方式访问文本BoundFields
。TemplateFields
您需要使用来FindControl
获取控件的参考(fe a TextBox
)。
如果您使用 aTemplateField
您还可以限制 aspx 标记上的文本:
<asp:TemplateField HeaderText="Commnents">
<ItemTemplate>
<asp:TextBox ID="txtID"
MaxLength="20" runat="server"
Text='<%# DataBinder.Eval(Container.DataItem, "Comments") %>'>
</asp:TextBox>
</ItemTemplate>
</asp:TemplateField>
于 2013-01-29T20:16:16.723 回答