实现文本一行超出隐藏显示以及强制长单词换行

本文介绍如何使用CSS实现文本一行超出隐藏并在尾部显示省略号的效果,同时讲解white-space、text-overflow及word-wrap等属性的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

文本一行超出隐藏显示

就是当你的文本字数过多超出容器的时候,让你超出部分隐藏,并在尾部显示省略号

首先写一个p标签,然后给他写一个较长的文本

<p>这是有段很长很长很长很长很长很长很长很长很长很长很长很长的文本</p>

给p标签写一个200px宽度和灰色背景颜色

p{
    width: 200px;
    background-color: #ccc;
}

效果
这里写图片描述

现在我们看到p标签会自动换行
接下来让文本强制一行显示

p{
    width: 200px;
    background-color: #ccc;
    white-space: nowrap;/*强制一行显示*/
}

效果
这里写图片描述

现在文本已经一行显示了,并且文本超出了p标签
接下来让超出部分隐藏

p{
    width: 200px;
    background-color: #ccc;
    white-space: nowrap;/*强制一行显示*/
    overflow:hidden;/*超出部分隐藏*/
}

效果
这里写图片描述

现在超出p标签部分已经隐藏了
接下来只要让最后显示省略号表示文本未完全显示就OK了

p{
    width: 200px;
    background-color: #ccc;
    white-space: nowrap;/*强制一行显示*/
    overflow:hidden;/*超出部分隐藏*/
    text-overflow: ellipsis;/*最后添加省略号*/
}

最终效果
这里写图片描述

white-space属性:

可选值说明
normal默认值,文本自动换行,空格和换行符会被忽略
pre类似<pre>标签作用,空白或换行都会被保留
nowrap强制一行显示
pre-wrap保留空白和换行符,但是正常地进行换行,也就是当你同一行中到达容器边界时,还是会自动换行,但是html中的空格和换行符都会被保留
pre-line合并空白符序列,但是保留换行符

text-overflow属性:

可选值说明
clip默认值,隐藏文字时不会有省略号结尾
break-word隐藏文字时省略号结尾

长单词强制换行

现在写一个p标签,里面写一个连续的字母

<p>pppppppppppppppppppppppppppppppppppppppppppppppppppppppppppp</p>

给p标签写一个200px宽度和灰色背景颜色

p{
    width: 200px;
    background-color: #ccc;
}

效果
这里写图片描述

现在我们的文本被识别为一个长单词,所以不会自动换行
接下来只用给p标签一个word-wrap:break-word;就可以自动换行

p{
    width: 200px;
    background-color: #ccc;
    word-wrap:break-word;
}

效果
这里写图片描述

word-wrap属性:

可选值说明
normalnormal为默认值,只在允许的断字点换行。就是只能在单词与单词之间或汉字与汉字之间换行
break-word运行对长单词或较长的联系字母(例如URL)进行端词从而换行
在微信开发者工具中实现文本超出显示省略号的效果,可以通过 CSS 样式来控制。这种效果在单行和多行文本中均可实现,但实现方式有所不同。 ### 单行文本超出显示省略号 对于单行文本,可以使用以下 CSS 样式来实现文本超出容器时显示省略号: ```css .single-line-ellipsis { overflow: hidden; white-space: nowrap; text-overflow: ellipsis; } ``` - `overflow: hidden;`:超出容器的部分将被隐藏。 - `white-space: nowrap;`:防止文本换行。 - `text-overflow: ellipsis;`:超出部分显示为省略号(...)。 ### 多行文本超出显示省略号 对于多行文本,微信小程序中可以通过 `-webkit-line-clamp` 属性来限制显示的行数,并在最后一行超出显示省略号: ```css .multi-line-ellipsis { display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 3; overflow: hidden; text-overflow: ellipsis; } ``` - `display: -webkit-box;`:将元素设置为弹性盒子模型。 - `-webkit-box-orient: vertical;`:设置盒子内容垂直排列。 - `-webkit-line-clamp: 3;`:限制最多显示的行数为 3 行。 - `overflow: hidden;`:超出部分隐藏。 - `text-overflow: ellipsis;`:超出部分显示为省略号(...)。 ### 注意事项 - 微信小程序中使用 `-webkit-line-clamp` 时,需要注意部分样式可能需要使用 `/*! autoprefixer: off */` 来关闭自动前缀,以确保样式生效。 - 如果文本中包含英文字符,可以添加 `word-break: break-all;` 来强制英文单词换行,避免因单词导致样式异常。 ### 示例代码 ```html <view class="single-line-ellipsis">这是一个单行文本超出显示省略号的例子。</view> <view class="multi-line-ellipsis">这是一个多行文本超出显示省略号的例子,这里的内容可能会比较,超过容器限制的行数。</view> ``` ```css .single-line-ellipsis { overflow: hidden; white-space: nowrap; text-overflow: ellipsis; } .multi-line-ellipsis { display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 3; overflow: hidden; text-overflow: ellipsis; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

eno_zeng

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值