在GridView的显示过程中常常会出现行中文本过长,导致GridView整体上看去时长时短的问题。那么就需要在GridView的行显示上截取文本的长度。
第一种方法是在GridView中加入OnRowDataBound时间,具体如下:
前台代码:
在GridView定义中加入OnRowDataBound="GV_RowDataBound"
后台代码:
protected void GV_RowDataBound(object sender, GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.DataRow)
{
e.Row.Cells[0].ToolTip = e.Row.Cells[0].Text;
e.Row.Cells[0].Text = e.Row.Cells[0].Text.Length > 15 ? e.Row.Cells[0].Text.Substring(0, 15) + "..." : e.Row.Cells[0].Text;
}
}
第二种方法是在一种特殊的情况下使用的,比如GridView中的一些元素需要在其他元素绑定之后再查找赋值,那么就要用到模版了。
前台代码:
添加一个用于显示文件名称的标签模板。
<asp:TemplateField HeaderText="文件名称">
<ItemTemplate>
<asp:Label ID="Label1" runat="server"></asp:Label>
</ItemTemplate>
<ItemStyle Width="280px" />
</asp:TemplateField>
后台代码:
DataTable dt = UF.GetFileByUserIDFlag1(UserID, 0);
DocGV.DataSource = dt;
DocGV.DataBind();
在绑定了之后再将查找结果name = dt.Rows[i][1].ToString();添加到模版上:
for (int i = 0; i < dt.Rows.Count; i++)
{
name = dt.Rows[i][1].ToString();
((Label)DocGV.Rows[i].FindControl("Label1")).ToolTip = name;
if (name.Length > 15)
name = name.Substring(0, 15) + "...";
((Label)DocGV.Rows[i].FindControl("Label1")).Text = name;
}
这两种方法更偏向于第一种,不过有些时候在“制作”GridView的数据源时比较懒,没有给出相应的字段,在绑定之后继续添加其他信息的时候可以考虑第二种方法。
但是呢~用第二种方法的时候我发现了一个问题。按照正常的分页方法,分页之后再次进行数据绑定的时候会出现bug,即页面数变化了之后,用标签模版的地方内容不见了。我调试后发现是由于分页的原理与我平时理解的不太一样。问题我不多说了,一调试就看的一清二楚,现在主要写上解决的方法:
DataTable dt = UF.GetFileByUserIDFlag1(UserID, 0);
DocGV.DataSource = dt;
DocGV.DataBind();
int n1 = DocGV.PageSize;//GridView每页的行数
int n2 = DocGV.PageIndex;//当前页索引
for (int i = n1 * n2; i < (n2 + 1) * n1 && i < dt.Rows.Count; i++)
{
name = dt.Rows[i][1].ToString();
((Label)DocGV.Rows[i % n1].FindControl("Label1")).ToolTip = name;
if (name.Length > 15)
name = name.Substring(0, 15) + "...";
((Label)DocGV.Rows[i % n1].FindControl("Label1")).Text = name;
}
基本上就是这样了。我水平有限,只是在编程过程中发现的一点小惊喜~和大家分享,如果你们有什么好的想法可以一起交流。
【源自CSDN】
第一种方法是在GridView中加入OnRowDataBound时间,具体如下:
前台代码:
在GridView定义中加入OnRowDataBound="GV_RowDataBound"
后台代码:
protected void GV_RowDataBound(object sender, GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.DataRow)
{
e.Row.Cells[0].ToolTip = e.Row.Cells[0].Text;
e.Row.Cells[0].Text = e.Row.Cells[0].Text.Length > 15 ? e.Row.Cells[0].Text.Substring(0, 15) + "..." : e.Row.Cells[0].Text;
}
}
第二种方法是在一种特殊的情况下使用的,比如GridView中的一些元素需要在其他元素绑定之后再查找赋值,那么就要用到模版了。
前台代码:
添加一个用于显示文件名称的标签模板。
<asp:TemplateField HeaderText="文件名称">
<ItemTemplate>
<asp:Label ID="Label1" runat="server"></asp:Label>
</ItemTemplate>
<ItemStyle Width="280px" />
</asp:TemplateField>
后台代码:
DataTable dt = UF.GetFileByUserIDFlag1(UserID, 0);
DocGV.DataSource = dt;
DocGV.DataBind();
在绑定了之后再将查找结果name = dt.Rows[i][1].ToString();添加到模版上:
for (int i = 0; i < dt.Rows.Count; i++)
{
name = dt.Rows[i][1].ToString();
((Label)DocGV.Rows[i].FindControl("Label1")).ToolTip = name;
if (name.Length > 15)
name = name.Substring(0, 15) + "...";
((Label)DocGV.Rows[i].FindControl("Label1")).Text = name;
}
这两种方法更偏向于第一种,不过有些时候在“制作”GridView的数据源时比较懒,没有给出相应的字段,在绑定之后继续添加其他信息的时候可以考虑第二种方法。
但是呢~用第二种方法的时候我发现了一个问题。按照正常的分页方法,分页之后再次进行数据绑定的时候会出现bug,即页面数变化了之后,用标签模版的地方内容不见了。我调试后发现是由于分页的原理与我平时理解的不太一样。问题我不多说了,一调试就看的一清二楚,现在主要写上解决的方法:
DataTable dt = UF.GetFileByUserIDFlag1(UserID, 0);
DocGV.DataSource = dt;
DocGV.DataBind();
int n1 = DocGV.PageSize;//GridView每页的行数
int n2 = DocGV.PageIndex;//当前页索引
for (int i = n1 * n2; i < (n2 + 1) * n1 && i < dt.Rows.Count; i++)
{
name = dt.Rows[i][1].ToString();
((Label)DocGV.Rows[i % n1].FindControl("Label1")).ToolTip = name;
if (name.Length > 15)
name = name.Substring(0, 15) + "...";
((Label)DocGV.Rows[i % n1].FindControl("Label1")).Text = name;
}
基本上就是这样了。我水平有限,只是在编程过程中发现的一点小惊喜~和大家分享,如果你们有什么好的想法可以一起交流。
【源自CSDN】