1. 程式人生 > >當文字過長時裁剪(顯示省略號或只裁剪 用CSS方法,不用程序)

當文字過長時裁剪(顯示省略號或只裁剪 用CSS方法,不用程序)

fire 省略號 fixed strong face con str 來源 type

原文發布時間為:2009-09-16 —— 來源於本人的百度文章 [由搬家工具導入]

CSS中ellipsis()应用【转】

CSS手册中text-overflow属性的定义:

  语法:
text-overflow : clip | ellipsis

参数:
clip :  不显示省略标记(...),而是简单的裁切
(clip这个参数是不常用的!)
ellipsis :  当对象内文本溢出时显示省略标记(...)

说明:
设置或检索是否使用一个省略标记(...)标示对象内文本的溢出。
请您注意,text-overflow:ellipsis属性在FF中是没有效果的。

  示例:
div { text-overflow : clip; }

  text-overflow是一个比较特殊的样式,我们可以用它代替我们通常所用的标题截取函数,而且这样做对 搜索引擎更加友好,如:标题文件有50个汉字,而我们的列表可能只有300px的宽度。如果用标题截取函数,则标题不是完整的,如果我们用CSS样式 text-overflow:ellipsis,输出的标题是完整的,只是受容器大小的局限不显示出来罢了。

  关于text-overflow属性如何应用,我们作如下的说明讲解:

  text-overflow属性仅是注解,当文本溢出时是否显示省略标记。并不具备其它的样式属性定义。我们想 要实现溢出时产生省略号的效果。还必须定义:强制文本在一行内显示(white-space:nowrap)及溢出内容为隐藏(overflow: hidden)。只有这样才能实现溢出文本显示省略号的效果。

  我们首页建立了一个无序列表UL,里面有几个列表项LI,内部建立了列表链接A。我们的测试主要在LI在进行,请注意观察,看如下的三段代码:

  一、仅定义text-overflow:ellipsis; 不能实现省略号效果。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>it55</title>
<style type="text/css">
ul {width:300px; margin:50px auto;}
li {width:300px; line-height:25px; text-overflow:ellipsis;}
a {color:#03c; font-size:13px;}
a:hover {color:#000;}
</style>
</head>
<body>
<ul>
<li><a href="/">CSS实战精萃 - Pro CSS Techniques </a>
<li><a href="/">CSS实战:id是狙击枪 class是双刃剑 合则两利分则两败</a>
<li><a href="/">CSS布局实例:CSS标签切换代码实例教程</a>
<li><a href="/">Web标准:改变您的网页制作思维方式 节省代码及结构与表现分离</a>
<li><a href="/">解决IE7以下版本不支持无A状态伪类的几种方法!</a>
<li><a href="/">CSS去除表格td默认间距及制作1px细线表格 </a>
</ul>

</body>
</html>

二、定义text-overflow:ellipsis; white-space:nowrap; 同样不能实现省略号效果。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>it55</title>
<style type="text/css">
ul {width:300px; margin:50px auto;}
li {width:300px; line-height:25px; text-overflow:ellipsis; white-space:nowrap;}
a {color:#03c; font-size:13px;}
a:hover {color:#000;}
</style>
</head>
<body>
<ul>
<li><a href="/">CSS实战精萃 - Pro CSS Techniques </a>
<li><a href="/">CSS实战:id是狙击枪 class是双刃剑 合则两利分则两败</a>
<li><a href="/">CSS布局实例:CSS标签切换代码实例教程</a>
<li><a href="/">Web标准:改变您的网页制作思维方式 节省代码及结构与表现分离</a>
<li><a href="/">解决IE7以下版本不支持无A状态伪类的几种方法!</a>
<li><a href="/">CSS去除表格td默认间距及制作1px细线表格 </a>
</ul>
</body>
</html>

三、按it55.com的教程,即本文所讲的方法,同时应用: text-overflow:ellipsis; white-space:nowrap; overflow:hidden; 实现了所想要得到的溢出文本显示省略号效果:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>it55</title>
<style type="text/css">
ul {width:300px; margin:50px auto;}
li {width:300px; line-height:25px; text-overflow:ellipsis; white-space:nowrap; overflow:hidden;}
a {color:#03c; font-size:13px;}
a:hover {color:#000;}
</style>
</head>
<body>
<ul>
<li><a href="/">CSS实战精萃 - Pro CSS Techniques </a>
<li><a href="/">CSS实战:id是狙击枪 class是双刃剑 合则两利分则两败</a>
<li><a href="/">CSS布局实例:CSS标签切换代码实例教程</a>
<li><a href="/">Web标准:改变您的网页制作思维方式 节省代码及结构与表现分离</a>
<li><a href="/">解决IE7以下版本不支持无A状态伪类的几种方法!</a>
<li><a href="/">CSS去除表格td默认间距及制作1px细线表格 </a>
</ul>
</body>
</html>

请您特别注意,text-overflow:ellipsis属性在FF中是没有效果的。


复制一下内容,直接拷贝到html文件中运行就可看到效果了
<html>
<head>
<style>
.text-overflow{
display:block;/*内联对象需加*/
width:200px;
word-break:keep-all;/* 不换行 */
white-space:nowrap;/* 不换行 */
overflow:hidden;/* 内容超出宽度时隐藏超出部分的内容 */
text-overflow:ellipsis;/* 当对象内文本溢出时显示省略标记(...) ;需与overflow:hidden;一起使用。*/
}
.table{
width:300px;
table-layout:fixed;/* 只有定义了表格的布局算法为fixed,下面td的定义才能起作用。 */
}
.table td{
width:100%;
word-break:keep-all;/* 不换行 */
white-space:nowrap;/* 不换行 */
overflow:hidden;/* 内容超出宽度时隐藏超出部分的内容 */
text-overflow:ellipsis;/* 当对象内文本溢出时显示省略标记(...) ;需与overflow:hidden;一起使用。*/
}
</style>
</head>
<body>
<div class="text-overflow">


另外附上几条刚学到的页面设计的小经验
1、页面中talbe的宽设置为100%右边还是会留下一个滚动条的空白,可以在body标记里在加上:

<body style="overflow:auto">

2、
@font-face {font-family:comic;src:url(http://url/font.eot);}

可以定义一个在本地没有的字体名称,调用方法:
<span style="font-family:comic;">just cd boy!</span>

3、firefox的document.createElement不支持内容里有HTML标签,也不支持innerText,但是支持innerHTML,可以用innerHTML指定其内容。

當文字過長時裁剪(顯示省略號或只裁剪 用CSS方法,不用程序)