CSS控制的内容超过容器宽度后显示省略号

本文介绍如何使用CSS3的text-overflow:ellipsis属性配合white-space:nowrap及overflow:hidden实现文本溢出时显示省略号效果,适用于列表标题等场景,提升用户体验和搜索引擎友好度。

text-overflow:ellipsis属性在FF中是没有效果的。

同时应用: text-overflow:ellipsis; white-space:nowrap; overflow:hidden; 实现了所想要得到的溢出文本显示省略号效果
text-overflow是一个比较特殊的属性,在CSS手册中,这个属性是这样定义的:

语法: 
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)。只有这样才能实现溢出文本显示省略号的效 果。

一般我们看到的比如新闻列表,为了使文字不回行,控制字数,会通过程序让多余的字符显示省略号,我们只使用CSS可以达到同样的效果,虽然不完美。


li { 
   width:50px; 
   white-space:nowrap; /*一行显示*/
   text-overflow:ellipsis; /*显示...*/
   overflow: hidden; /*缺少无效*/
   }

首先是一个容器,可以是div,li,td等等,先定义宽度,“white-space:nowrap”是强制在一行内显示所有文本,不回行。“text-overflow:ellipsis”就是关键了。

text- overflow是CSS3新增的属性,IE6以上版本支持。它可以带2个参数:clip [不显示省略标记(...),而是简单的裁切],ellipsis[当对象内文本溢出时显示省略标记(...)]。所以,这个方法是不支持Firefox 的。因此,我们还要加上一句overflow: hidden,让多余文字在ff中隐藏

 

### 单行文本超出宽度显示省略号CSS 中,可以通过 `text-overflow: ellipsis` 属性实现单行文本超出容器宽度时自动显示省略号(…)的效果。此方法需要结合 `overflow: hidden` 和 `white-space: nowrap` 以确保文本不会换行且多余内容被隐藏[^1]。 #### 示例代码: ```css .ellipsis { width: 200px; /* 设置容器宽度 */ white-space: nowrap; /* 文本不换行 */ overflow: hidden; /* 隐藏超出部分 */ text-overflow: ellipsis; /* 显示省略号 */ } ``` 对应的 HTML 结构如下: ```html <div class="ellipsis"> 这是一段很长的文本,当它超出容器宽度时将显示省略号。 </div> ``` 该样式确保了当文本内容超过指定宽度时,浏览器会隐藏多余内容并在末尾显示省略号,提示用户存在更多未显示内容[^3]。 --- ### 多行文本超出显示省略号 对于多行文本的截断需求,可以使用 `-webkit-line-clamp` 属性来限制显示最大行数,并配合 `display: -webkit-box` 和 `-webkit-box-orient: vertical` 实现垂直方向上的文本截断[^2]。 #### 示例代码: ```css .multi-line-ellipsis { display: -webkit-box; overflow: hidden; text-overflow: ellipsis; word-wrap: break-word; white-space: normal; -webkit-line-clamp: 3; /* 控制最多显示3行 */ -webkit-box-orient: vertical; } ``` HTML 结构如下: ```html <div class="multi-line-ellipsis"> 测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本测试文本 </div> ``` 此方案利用 `-webkit-box` 模型实现多行文本的截断,并在达到指定行数后添加省略号,适用于现代浏览器环境[^4]。 --- ### 替换默认省略号为自定义字符 若希望将默认的省略号 `...` 替换为其他字符(例如中文省略号 `…`),可以通过伪元素 `::after` 或 `:after` 自定义内容。但需注意,在标准 `text-overflow: ellipsis` 模式下无法直接修改省略符号,因此需要通过额外的 HTML 元素或伪类实现[^5]。 #### 示例代码: ```css .ellipsis-custom::after { content: '…'; /* 使用中文省略号替代默认的... */ position: absolute; background: white; /* 遮挡背景,避免文字重叠 */ padding-left: 5px; } ``` 同时需要设置容器为相对定位并限制高度: ```css .container { position: relative; width: 200px; max-height: 20px; /* 根据字体大小调整 */ overflow: hidden; } ``` HTML 结构如下: ```html <div class="container"> <span class="ellipsis-custom">这是一段非常长的文本内容</span> </div> ``` 该方法允许灵活控制省略符号的样式和位置,但需要注意兼容性问题,尤其在旧版浏览器中可能无法正常显示。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值