强制中英文换行及超出显示省略号的问题

本文详细介绍如何使用CSS控制文本布局,包括强制中英文换行、强制不换行、文本超出显示省略号及多行省略号等技巧,适用于网页设计与响应式布局优化。

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

目录

1、强制中英文换行

①  强制英文换行(二选一)

② 强制中文换行,只对中文有作用

2、强制不换行

3、超出显示省略号

4、超出2行,显示省略号


1、强制中英文换行

当固定盒子的宽度时,中文会换行,但是英文和数字不换行。

解决的方法如下:

①  强制英文换行(二选一)

word-break: break-all;
word-wrap: break-word;

② 强制中文换行,只对中文有作用

white-space: pre-wrap;

2、强制不换行

中英文都有作用。

white-space: nowrap;

3、超出显示省略号

超出不换行,超出部分隐藏且以省略号形式出现(部分浏览器支持)

中英文都有作用。

主要代码:

white-space: nowrap; // 规定段落中的文本不换行
overflow: hidden; // 溢出隐藏
text-overflow: ellipsis; // 文本溢出用省略号表示

如图效果:

     

代码:

<div class="box-parent">
    <div class="box">大家好,我是小草莓蹦蹦跳跳,很高兴认识你</div>
    <div class="box">大家好,我是小草莓蹦蹦跳跳,66666666666</div>
    <div class="box">大家好,我是小草莓蹦蹦跳跳,aaaaaaaaaaa</div>
</div>
.box-parent {
    margin: 100px;
}

.box {
    width: 100px;
    background-color: sandybrown;
    margin-bottom: 20px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

4、超出2行,显示省略号

超出2行不换行,超出部分隐藏且以省略号形式出现(部分浏览器支持)

中英文都有作用。

主要代码:

    overflow: hidden; // 溢出隐藏
    text-overflow: ellipsis; // 文本溢出用省略号表示
    display: -webkit-box; // 作为弹性伸缩盒子模型显示
    -webkit-box-orient: vertical; // 设置伸缩盒子的子元素排列方式: 从上到下垂直排列
    -webkit-line-clamp: 2; // 显示的行数

// 注意:由于上面的三个属性都是 CSS3 的属性,没有浏览器可以兼容,所以要在前面加一个 -webkit- 来兼容
部分浏览器。

如要想要超出N行再显示省略号,只要改变 -webkit-line-clamp 的值就可以。

如图效果:

   

<div class="box-parent">
    <div class="box">大家好,我是小草莓蹦蹦跳跳,很高兴认识你</div>
    <div class="box">大家好,我是小草莓蹦蹦跳跳,66666666666</div>
    <div class="box">大家好,我是小草莓蹦蹦跳跳,aaaaaaaaaaa</div>
</div>
.box {
    width: 100px;
    background-color: sandybrown;
    margin-bottom: 20px;
    overflow: hidden;

    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

在微信开发者工具中实现文本超出显示省略号的效果,可以通过 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; } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值