• 微软原版系统

  • 一键重装系统

  • 纯净系统

  • 在线技术客服

魔法猪系统重装大师 一键在线制作启动 U 盘 PE 系统 用一键重装的魔法拯救失去灵魂的系统
当前位置:首页 > 教程 > 电脑教程

通过CSS解决文字溢出与截断的方案

时间:2015年04月02日 15:30:51    来源:魔法猪系统重装大师官网    人气:8784

在网站的首页或者边栏输出新闻条目的时候,经常会遇到文字溢出与截断的问题。这个问题曾经困扰了我很久,最近又重新遇到,我本着“每天进步一点点”的态度,继续改进方法,查阅文章,几经测试,终于确定使用纯CSS的方法解决这个问题。关于这个问题,我用编程的方式解决过,也用js攻克过,现在CSS的标准属性和各浏览器私有属性的发展给我们带来重新解决这一问题的机会,我这样做也算是一种新的尝试吧。

假定我要实现一组新闻条目的输出,每个新闻标题后面附带有新闻发表的日期,日期要完整显示,但标题和日期的总长度超过一定数值就要截断标题。

看完演示,重点介绍一下CSS代码中用到的一个关键属性:text-overflow 。

text-overflow: ellipsis;

这个属性定义了当文字溢出的时候如何截断文字,属性值为 ellipsis 的时候就是当对象内文本溢出的时候显示省略标记(…),该属性支持IE6以上的版本IE7/8/9和除firefox以外的现代标准浏览器:Chrome、Safari。对于Opera,有一个相应的私有属性:

-o-text-overflow: ellipsis;

新闻条目的结构,我是这样写的:

下面是完整的CSS代码:

* {
    margin:0;
    padding:0;
}

#news {
    margin-top:100px;
    margin-left:100px;
    list-style:none;
    width:156px;  /*这个宽度可以深究一下,它是不包含日期长度的*/
}
#news:after {
    content:'';
    display:block;
    clear:both;
    height:0px;
}
#news li {
    clear:both;  /*清除li中的浮动*/
}
#news li a {
    float:left;  /*标题向左浮动*/
    color:#333;
    text-decoration:none;
    font-size:13px;
    max-width:156px;  /*给标准浏览器一个最大宽度*/
    height:24px;
    white-space:nowrap !important;  /*强制文字不换行(标准浏览器)*/
    white-space:normal;  /*溢出的时候文字换行,并配合上面的固定高度,对文字进行裁切*/
    overflow:hidden;
    text-overflow:ellipsis;  /*截断文字,显示省略号(...)*/
    -o-text-overflow:ellipsis;  /*Opera的专用截断文字的属性*/
    background:none;  /*解决IE6的莫名高度BUG,试试在IE6下去掉这个属性*/
}
#news li a:hover {
    color:#000;
    text-decoration:underline;
}
#news li span {
    float:left;  
    color:#666;
    padding-left:10px;
    margin-right:-99px; 
    _position:relative; 
}

我所说的以纯CSS的方法解决文字溢出与截断的问题基本上就是这样。

不过,这个方法有个不得不正视的问题,那就是对firefox的兼容性,如果哪位大侠有好的办法,请留言指教。

通过,CSS,解决,文字,溢出,与,截断,的,方案,在,
栏目:电脑教程 阅读:1000 2023/12/27
Win7教程 更多>>
U盘教程 更多>>
Win10教程 更多>>
魔法猪学院 更多>>

Copyright © 2015-2023 魔法猪 魔法猪系统重装大师

本站发布的系统仅为个人学习测试使用,请在下载后24小时内删除,不得用于任何商业用途,否则后果自负,请支持购买微软正版软件。

在线客服 查看微信 返回顶部