0

我有一个使用的 gridview <asp:BoundField DataField="Comments" HeaderText="COMMENTS" />,我想在填充 gridview 时只显示 Commemnt 列中的前 20 个字符。有没有办法在VB中完成这个?谢谢你。

4

1 回答 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

请注意,您只能使用 以这种方式访问​​文本BoundFieldsTemplateFields您需要使用来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 回答