您的位置:首页 > Web前端 > CSS

让<li>不显示超出内容,显示... (编程方法和CSS方法)

2012-02-24 11:49 351 查看




在用户控件的repeter控件中放了一个<li>:

<li class="goodsname">
<a id="A2" target="_blank" title='<%# Eval("ProductName") %>' href='<%# Eval("ProductID","~/ViewProduct.aspx?ID={0}") %>' runat="server">
<%# Eval("ProductName") %></a>
</li> 希望商品名超链接文字只显示行,超出2行范围的用…显示。

有2个办法可以实现,第一:

把 <%# Eval("ProductName") %> 改写为 <%# GetString( Eval("ProductName" )) %>

然后在用户控件.cs文件中添加下面这个方法:

protected string GetString(object obj)
{
string str = Convert.ToString(obj);
string strReturn = "**";
if (!string.IsNullOrEmpty(str))
{
//如果商品名在首页最新商品列表中超过2行,将超出的文字省略为...
if (str.Length > 34)
{
strReturn = str.Substring(0, 34) + "...";
}
else
{
strReturn = str;
}
}
return strReturn;
} 第二种方法只能让超出一行范围的文字显示为…, 多行无法使用这个方法: div+css设置列表li超出部分显示省略号 在网页设计中,会遇到文本超过固定长度导致整体的网页变形的情况。程序员往往需要截取固定的长度来实现某些固定长度的控制。介绍一种直接采用CSS 的代码控制来实现文本截取的方法。与程序员的直接字符截取的方式有点区别,其优势是可以自动控制文本显示的长度;缺点是不同浏览器的兼容性并不完美。使用到 overflow,text-overflow,white-space 这三个主要的属性,其他的代码属于修饰作用。 CSS代码:
<style>
.texthidden{
width:200px;
overflow:hidden;
text-overflow:ellipsis;
white-space:nowrap;
border:1px solid #ddd;}
</style> HTML代码:
<div class="texthidden">
CSS让容器的溢出部分内容隐藏起来
</div> 代码分析:
1. width:200px; //指定宽度:
2. overflow:hidden; //将超出内容隐藏
3. text-overflow:ellipsis; //IE专用属性,文本溢出时显示省略标记();其他浏览器不支持。
4. white-space:nowrap; //强制内容不换行。强制在同一行内显示所有文本,直到文本结束或者遭遇 br 元素 目前使用这种方法比较成功的示例是Gmail的内容显示,在IE下达到最好的效果。如果是FF那就比较糟糕,总是会出现截取半个中文的效果。其中涉及到最主要的原因是 text-overflow 这个属性只在IE下有效,目前很多CSS属性也存在这个问题,特别重要的是Margin和Padding这两个属性,往往导致页面出现各种不同的效果;在页面设计的时候,需要注意这些属性在不同浏览器的显示效果。 ===========配图=============

_______________________________方法二。_____________________________________________________ <style> .ellipsis a{display: block;width: 300px;overflow: hidden;white-space: nowrap;-o-text-overflow: ellipsis;text-overflow: ellipsis;}
/* firefox only */
.ellipsis:not(p) {clear: both;}
.ellipsis:not(p) a {max-width: 300px;float: left;}
.ellipsis:not(p):after {content: "..";float: left;width: 25px;padding-left: 1px;}
</style> <div class="ellipsis"><a href="">在被征服后的岁月里,蒂卡尔自己也走上侵略道路,在玛雅全境扩张它的势力范围。</a></div> 效果和上圈差不多,只是省略号的个数在不同浏览器中的个数也不同。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: