html5中文学习网

您的位置: 首页 > 网页制作 > css教程 » 正文

通过纯CSS样式实现DIV元素中多行文本超长自动省略号_CSS教程_CSS_网页制作

[ ] 已经帮助:人解决问题
点评:可以通过css样式实现DIV元素中文本超长后自动截断并以省略号结尾,一般情况下都是使用javascript,其实使用纯CSS样式也可以做到
在CSS中,我们可以通过下面的样式实现DIV元素中文本超长后自动截断并以省略号结尾: 9tuHTML5中文学习网 - HTML5先行者学习网

复制代码
代码如下:
9tuHTML5中文学习网 - HTML5先行者学习网
overflow: hidden; 9tuHTML5中文学习网 - HTML5先行者学习网
word-break: normal; 9tuHTML5中文学习网 - HTML5先行者学习网
text-overflow: ellipsis; 9tuHTML5中文学习网 - HTML5先行者学习网
9tuHTML5中文学习网 - HTML5先行者学习网
text-overflow: ellipsis是实现文本截断后以省略号结尾的关键样式,但问题是如果添加该样式则DIV元素内的文本无法自动换行,也就是说该效果只被允许在单行文本上实现。另外,word-break: normal可以防止文字被部分截断,这个在内容为英文的情况下显得尤其重要。 9tuHTML5中文学习网 - HTML5先行者学习网
9tuHTML5中文学习网 - HTML5先行者学习网
要实现多行文本自动截断以省略号结尾的效果,通常的做法是使用JavaScript脚本。下面这些文章给出了如何通过脚本进行字符串截断,不过仅限于英文环境。 9tuHTML5中文学习网 - HTML5先行者学习网
9tuHTML5中文学习网 - HTML5先行者学习网
http://www.barelyfitz.com/projects/truncate/ 9tuHTML5中文学习网 - HTML5先行者学习网
9tuHTML5中文学习网 - HTML5先行者学习网
http://www.javascriptsource.com/miscellaneous/truncate-text.html 9tuHTML5中文学习网 - HTML5先行者学习网
9tuHTML5中文学习网 - HTML5先行者学习网
http://www.javascriptbank.com/truncate-html-text.html/en/ 9tuHTML5中文学习网 - HTML5先行者学习网
9tuHTML5中文学习网 - HTML5先行者学习网
使用纯CSS样式来实现该效果则会稍微有些麻烦,你需要懂得如何在CSS中进行hack。这里是一个可以在多个通用浏览器中实现该效果的例子: 9tuHTML5中文学习网 - HTML5先行者学习网

复制代码
代码如下:
9tuHTML5中文学习网 - HTML5先行者学习网
<!DOCTYPE HTML> 9tuHTML5中文学习网 - HTML5先行者学习网
<html> 9tuHTML5中文学习网 - HTML5先行者学习网
<head> 9tuHTML5中文学习网 - HTML5先行者学习网
<style> 9tuHTML5中文学习网 - HTML5先行者学习网
html, body, p { margin: 0; padding: 0; font-family: sans-serif;} 9tuHTML5中文学习网 - HTML5先行者学习网
.ellipsis { 9tuHTML5中文学习网 - HTML5先行者学习网
overflow: hidden; 9tuHTML5中文学习网 - HTML5先行者学习网
height: 200px; 9tuHTML5中文学习网 - HTML5先行者学习网
line-height: 25px; 9tuHTML5中文学习网 - HTML5先行者学习网
margin: 20px; 9tuHTML5中文学习网 - HTML5先行者学习网
border: 5px solid #AAA; } 9tuHTML5中文学习网 - HTML5先行者学习网
.ellipsis:before { 9tuHTML5中文学习网 - HTML5先行者学习网
content:""; 9tuHTML5中文学习网 - HTML5先行者学习网
float: left; 9tuHTML5中文学习网 - HTML5先行者学习网
width: 5px; height: 200px; } 9tuHTML5中文学习网 - HTML5先行者学习网
.ellipsis > *:first-child { 9tuHTML5中文学习网 - HTML5先行者学习网
float: right; 9tuHTML5中文学习网 - HTML5先行者学习网
width: 100%; 9tuHTML5中文学习网 - HTML5先行者学习网
margin-left: -5px; } 9tuHTML5中文学习网 - HTML5先行者学习网
.ellipsis:after { 9tuHTML5中文学习网 - HTML5先行者学习网
content: "/02026"; 9tuHTML5中文学习网 - HTML5先行者学习网
box-sizing: content-box; 9tuHTML5中文学习网 - HTML5先行者学习网
-webkit-box-sizing: content-box; 9tuHTML5中文学习网 - HTML5先行者学习网
-moz-box-sizing: content-box; 9tuHTML5中文学习网 - HTML5先行者学习网
float: right; position: relative; 9tuHTML5中文学习网 - HTML5先行者学习网
top: -25px; left: 100%; 9tuHTML5中文学习网 - HTML5先行者学习网
width: 3em; margin-left: -3em; 9tuHTML5中文学习网 - HTML5先行者学习网
padding-right: 5px; 9tuHTML5中文学习网 - HTML5先行者学习网
text-align: right; 9tuHTML5中文学习网 - HTML5先行者学习网
background: -webkit-gradient(linear, left top, right top, 9tuHTML5中文学习网 - HTML5先行者学习网
from(rgba(255, 255, 255, 0)), to(white), color-stop(50%, white)); 9tuHTML5中文学习网 - HTML5先行者学习网
background: -moz-linear-gradient(to right, rgba(255, 255, 255, 0), white 50%, white); 9tuHTML5中文学习网 - HTML5先行者学习网
background: -o-linear-gradient(to right, rgba(255, 255, 255, 0), white 50%, white); 9tuHTML5中文学习网 - HTML5先行者学习网
background: -ms-linear-gradient(to right, rgba(255, 255, 255, 0), white 50%, white); 9tuHTML5中文学习网 - HTML5先行者学习网
background: linear-gradient(to right, rgba(255, 255, 255, 0), white 50%, white); } 9tuHTML5中文学习网 - HTML5先行者学习网
</style> 9tuHTML5中文学习网 - HTML5先行者学习网
</head> 9tuHTML5中文学习网 - HTML5先行者学习网
<body> 9tuHTML5中文学习网 - HTML5先行者学习网
<div class="ellipsis"><div> 9tuHTML5中文学习网 - HTML5先行者学习网
<p>Call me Ishmael. Some years ago &ndash; never mind how long precisely &ndash; having little or no money in my purse, and nothing particular to interest me on shore, I thought I would sail about a little and see the watery part of the world. It is a way I have of driving off the spleen, and regulating the circulation. Whenever I find myself growing grim about the mouth; whenever it is a damp, drizzly November in my soul; whenever I find myself involuntarily pausing before coffin warehouses, and bringing up the rear of every funeral I meet; and especially whenever my hypos get such an upper hand of me, that it requires a strong moral principle to prevent me from deliberately stepping into the street, and methodically knocking people's hats off &ndash; then, I account it high time to get to sea as soon as I can.</p> 9tuHTML5中文学习网 - HTML5先行者学习网
</div></div> 9tuHTML5中文学习网 - HTML5先行者学习网
</body> 9tuHTML5中文学习网 - HTML5先行者学习网
</html> 9tuHTML5中文学习网 - HTML5先行者学习网
9tuHTML5中文学习网 - HTML5先行者学习网
通过修改.ellipsis和.ellipsis:before样式中height属性的值来指定容器的高度。该样式的实现在多个不同版本的浏览器下测试通过,注意如果你是在IE下查看则需要确保你的文档模型必须是在标准模式下,即Document Mode必须是Standards。
(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助