绑定SqlDataSource的Gridview字符串字段长度截取
2008-08-17 10:45
393 查看
一批现有代码,页面都是直接绑定了SqlDataSource的Gridview,现在想对字段显示的长度做一个控制,目的是不想因为字段过长折到下一行,使每行高度不同。改动最小,最简单的方案是什么呢
听说可以用CSS使过长的字段隐起来吗?
字符串不能格式化真不方便...
----------------------------------------------------------------------
天台gridview中 加模版列
<asp:TemplateField HeaderText=" 内容 ">
<ItemStyle HorizontalAlign="Center" />
<HeaderStyle HorizontalAlign="Center" Width="15%" />
<ItemTemplate>
<%# CutString(Convert.ToString(Eval("Content")), 20)%>
</ItemTemplate>
</asp:TemplateField>
后台代码中
/// <summary>
/// 字符长度控制 中文 英文识别!
/// 注:一个汉字作为2个字符长度处理
/// </summary>
/// <param name="str">要进行切割的字符串</param>
/// <param name="len">返回的长度(自动识别中英文)</param>
/// <returns></returns>
protected string CutString(string str, int len)
{
byte[] sarr = System.Text.Encoding.Default.GetBytes(str);
if (sarr.Length > len)
return System.Text.Encoding.Default.GetString(sarr, 0, len) + "...";
else
return str;
}
--------------------------------------------------------
给个参考吧
<asp:repeater id="FeedBackList" Runat="server">
<ItemTemplate>
<tr height="35px" onmouseout="this.style.backgroundColor='#FFFFFF'" onmouseover="this.style.backgroundColor='#eeeffe'">
<td align="center"><%# DataBinder.Eval(Container.DataItem,"username")%></td>
<td><%# DataBinder.Eval(Container.DataItem,"title")%></td>
<td><%# DataBinder.Eval(Container.DataItem,"content").ToString().Length>15?DataBinder.Eval(Container.DataItem,"content").ToString().Substring(0,15)+"...":DataBinder.Eval(Container.DataItem,"content").ToString()%></td>
<td align="center"><%# DataBinder.Eval(Container.DataItem,"date")%></td>
<td align="center">
<span style="cursor:hand" id='<%# DataBinder.Eval(Container.DataItem,"id")%>' onclick=Del(this)>删除</span>
<a href="FeedBackdetails.aspx?id='<%# _fcksavedurl=""FeedBackdetails.aspx?id='<%#" DataBinder.Eval(Container.DataItem,"id")%>'">查看详情</a>
</td>
</tr>
</ItemTemplate>
</asp:repeater>
--------------------------------------------------------
唉,模版列我也会加阿
有没有改动更小的方法,没有的话下午给楼上2位没人50分好了
--------------------------------------------------------
<style>.stringCut{
width:50px; overflow:hidden;text-overflow:ellipsis; white-space:nowrap;
}</style>
<div class="stringCut">Linux+Java+Oracle开发方案 从c#程序员到微软架构工程师 </div>
--------------------------------------------------------
接分
--------------------------------------------------------
在CS里面GRIDVIEW的事件截取 e.Row.Cells[2] 这是那个地段!选择框为0然后往后排
protected void gvFlash_RowDataBound(object sender, GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.DataRow)
{
e.Row.Cells[2].Text=e.Row.Cells[2].Text.ToString().PadRight(50).Substring(0,50);
}
}
听说可以用CSS使过长的字段隐起来吗?
字符串不能格式化真不方便...
----------------------------------------------------------------------
天台gridview中 加模版列
<asp:TemplateField HeaderText=" 内容 ">
<ItemStyle HorizontalAlign="Center" />
<HeaderStyle HorizontalAlign="Center" Width="15%" />
<ItemTemplate>
<%# CutString(Convert.ToString(Eval("Content")), 20)%>
</ItemTemplate>
</asp:TemplateField>
后台代码中
/// <summary>
/// 字符长度控制 中文 英文识别!
/// 注:一个汉字作为2个字符长度处理
/// </summary>
/// <param name="str">要进行切割的字符串</param>
/// <param name="len">返回的长度(自动识别中英文)</param>
/// <returns></returns>
protected string CutString(string str, int len)
{
byte[] sarr = System.Text.Encoding.Default.GetBytes(str);
if (sarr.Length > len)
return System.Text.Encoding.Default.GetString(sarr, 0, len) + "...";
else
return str;
}
--------------------------------------------------------
给个参考吧
<asp:repeater id="FeedBackList" Runat="server">
<ItemTemplate>
<tr height="35px" onmouseout="this.style.backgroundColor='#FFFFFF'" onmouseover="this.style.backgroundColor='#eeeffe'">
<td align="center"><%# DataBinder.Eval(Container.DataItem,"username")%></td>
<td><%# DataBinder.Eval(Container.DataItem,"title")%></td>
<td><%# DataBinder.Eval(Container.DataItem,"content").ToString().Length>15?DataBinder.Eval(Container.DataItem,"content").ToString().Substring(0,15)+"...":DataBinder.Eval(Container.DataItem,"content").ToString()%></td>
<td align="center"><%# DataBinder.Eval(Container.DataItem,"date")%></td>
<td align="center">
<span style="cursor:hand" id='<%# DataBinder.Eval(Container.DataItem,"id")%>' onclick=Del(this)>删除</span>
<a href="FeedBackdetails.aspx?id='<%# _fcksavedurl=""FeedBackdetails.aspx?id='<%#" DataBinder.Eval(Container.DataItem,"id")%>'">查看详情</a>
</td>
</tr>
</ItemTemplate>
</asp:repeater>
--------------------------------------------------------
唉,模版列我也会加阿
有没有改动更小的方法,没有的话下午给楼上2位没人50分好了
--------------------------------------------------------
<style>.stringCut{
width:50px; overflow:hidden;text-overflow:ellipsis; white-space:nowrap;
}</style>
<div class="stringCut">Linux+Java+Oracle开发方案 从c#程序员到微软架构工程师 </div>
--------------------------------------------------------
接分
--------------------------------------------------------
在CS里面GRIDVIEW的事件截取 e.Row.Cells[2] 这是那个地段!选择框为0然后往后排
protected void gvFlash_RowDataBound(object sender, GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.DataRow)
{
e.Row.Cells[2].Text=e.Row.Cells[2].Text.ToString().PadRight(50).Substring(0,50);
}
}
相关文章推荐
- 绑定SqlDataSource的Gridview字符串字段长度截取
- 绑定SqlDataSource的Gridview字符串字段长度截取
- 绑定SqlDataSource的Gridview字符串字段长度截取(转)
- gridview 实现排序 (在不是使用sqlDataSource控件,而在后台编码绑定gridview时,指定那个字段排序时使用。本例用了单层结构,可修改后应用于多层)
- 为DataList、GridView赋值字段截取长度
- sql中从指定位置截取指定长度字符串
- sql中根据字段字符串的长度进行删除
- Oracle截取字符串去掉字段末尾指定长度的字符
- sql截取字段的固定长度
- 数据库中判断字段中字符串长度 截取字符,字符转换,
- sql语句,如何截取指定字段某一个字符出现后的后面的字符串吗?
- GridView截取某一列字符串的长度,
- gridview绑定linqdatasource后获取gridview中的字段
- 绑定gridview单元格内容过长,用tooltip,单元格截取指定长度,鼠标停留时显示全部内容,
- 手动绑定SQLDataSource到GridView后分页的问题(转)
- 删除SQL表中某字段字符为空,Null,零长度字符串,将删除记录
- SQL截取非固定长度(有关键字符)的字符串
- gridview 数据绑定 截取字符串 eval 和 bind
- sql中截取和算出字符串的长度
- sql---截取字段中一段字符串并对该字符串进行替换