【CSS】关于文字的换行问题

给固定宽度的div中写入一些文字,你会发现文字可能会超出,实例如下:

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .text {
            width: 150px;
            border: 1px solid #ccc;
            margin-bottom: 20px;
        }
    </style>
</head>

<body>
    <div class="text text1">hello今天是个好日子呀天气晴朗阳光明媚????????????</div>
    <div class="text text2">hello今天是个好日子呀天气晴朗阳光明媚abcabcabcabcabcabcabc</div>
</body>

</html>

上述代码在chrome上的展示结果如下:

那么如何让div中的文字不超出呢?这就涉及到 word-break 和 line-break 属性

在上面代码中给text1、text2加上以下样式:

css 复制代码
.text1 {
    /* 加了word-break后在chrome中还是会超出,但是在ios中并不会超出了 */
    /* word-break: break-all; */
    line-break: anywhere;
}

.text2 {
    word-break: break-all;
    /* 加了line-break后也能实现不超出的效果 */
    /* line-break: anywhere; */
}

在chrome上的展示结果就变成如下:

参考文章:

https://zhuanlan.zhihu.com/p/665011773

line-break介绍:https://blog.csdn.net/broken_promise/article/details/127039350

word-break属性:https://www.php.cn/faq/415051.html

相关推荐
前端那点事2 小时前
Vue3 Tree-Shaking 原理解析
前端·vue.js
DROm RAPS2 小时前
SQL 实战:复杂数据去重与唯一值提取
前端·数据库·sql
爱怪笑的小杰杰2 小时前
uni-app Vue3 国际化最佳实践:告别应用重启,优雅实现多语言切换
前端·vue.js·uni-app
大流星2 小时前
敲黑板!async/await应用原理
前端·javascript
知了清语3 小时前
使用 codex + GPT 5.4 分析已实现的 数据看板
前端
白活了3 小时前
Claude Code 安装并配置 Coding Plan
前端·人工智能·后端
qq_12084093713 小时前
Three.js 工程向:相机控制与交互手感调优(OrbitControls)
前端·javascript·orbitcontrols
疯狂的魔鬼3 小时前
从 5 个 Hooks 到注册表模式:Vue 3 复杂详情页的架构演进与原则沉淀
前端·架构
enoughisenough3 小时前
WEB网络通信
前端
We་ct3 小时前
LeetCode 300. 最长递增子序列:两种解法从入门到优化
开发语言·前端·javascript·算法·leetcode·typescript