如何解决 Highlight.js 中长代码行溢出页面的问题

来源:AI社区作者:会飞的猪头衔:草根站长
导读:本期聚焦于小伙伴创作的《如何解决 Highlight.js 中长代码行溢出页面的问题》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《如何解决 Highlight.js 中长代码行溢出页面的问题》有用,将其分享出去将是对创作者最好的鼓励。

在使用Highlight.js进行代码高亮展示时,长代码行超出容器宽度导致页面横向滚动是开发者经常遇到的问题,这种情况会破坏页面布局,降低用户的阅读体验。要解决这个问题,我们可以从样式调整、配置优化等多个维度入手。

如何解决 Highlight.js 中长代码行溢出页面的问题

问题产生的原因

Highlight.js默认生成的代码块不会自动换行,当单行代码的长度超过外层容器的宽度时,就会出现溢出的情况。另外如果外层容器没有设置合适的溢出处理规则,也会导致整个页面被撑开。

解决方案一:通过CSS样式实现自动换行

这是最直接有效的解决方式,我们只需要给Highlight.js生成的代码容器添加对应的CSS样式即可。Highlight.js高亮后的代码通常会被包裹在precode标签中,我们可以针对这两个标签设置样式。

/* 针对代码块的pre容器设置 */
pre.hljs {
    padding: 12px;
    border-radius: 6px;
    /* 允许横向滚动,避免直接撑开页面 */
    overflow-x: auto;
    /* 设置最大宽度不超过父容器 */
    max-width: 100%;
}

/* 针对code标签设置自动换行 */
pre.hljs code {
    /* 保留空白符序列,但是正常换行 */
    white-space: pre-wrap;
    /* 在单词内换行,避免长单词溢出 */
    word-wrap: break-word;
    /* 长单词换行规则 */
    word-break: break-all;
}

这里的white-space: pre-wrap可以保留代码原有的缩进和空格,同时允许内容自动换行;word-break: break-all则可以让长字符串在任意位置换行,避免因为连续无空格的长内容导致溢出。

解决方案二:限制代码容器的宽度

如果页面的布局有固定的内容区域,我们可以给代码块的外层容器设置明确的宽度限制,避免它超出布局范围。

/* 代码块外层容器样式 */
.code-container {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    box-sizing: border-box;
}

/* 代码块继承容器宽度 */
.code-container pre.hljs {
    width: 100%;
}

解决方案三:处理特殊场景的长代码

有些场景下代码包含很长的URL或者无空格的字符串,即使设置了上述样式也可能出现换行异常,这时候可以给这类特殊内容添加额外的处理样式。

/* 针对长URL或者无空格字符串的处理 */
pre.hljs code .long-content {
    word-break: break-all;
    word-wrap: break-word;
}

对应的HTML结构可以在生成代码的时候给特殊内容添加对应的类名:

<pre class="hljs">
    <code>
        请求地址:<span class="long-content">https://ipipp.com/api/v1/user/info?uid=123456789&token=abcdefghijklmnopqrstuvwxyz</span>
    </code>
</pre>

验证方案效果

我们可以写一个简单的测试页面验证上述方案是否生效:

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <title>Highlight.js长代码测试</title>
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/highlightjs/cdn-release@11.9.0/build/styles/default.min.css">
    <style>
        pre.hljs {
            padding: 12px;
            border-radius: 6px;
            overflow-x: auto;
            max-width: 100%;
        }
        pre.hljs code {
            white-space: pre-wrap;
            word-wrap: break-word;
            word-break: break-all;
        }
    </style>
</head>
<body>
    <pre class="hljs">
        <code>
            function testLongCodeLine() {
                const longString = "这是一段非常长的字符串内容,用来测试Highlight.js的长代码行是否会溢出页面,如果样式设置正确,这段内容应该会自动换行展示,不会出现横向滚动条";
                console.log(longString);
            }
        </code>
    </pre>
    <script src="https://cdn.jsdelivr.net/gh/highlightjs/cdn-release@11.9.0/build/highlight.min.js"></script>
    <script>hljs.highlightAll();</script>
</body>
</html>

打开这个页面后,如果长字符串自动换行,没有出现横向滚动条,就说明我们的解决方案生效了。

注意事项

  • 不要同时设置white-space: nowrap和自动换行的样式,这两个属性会互相冲突,导致换行失效。
  • 如果页面使用了响应式布局,需要确保代码容器的宽度设置适配移动端,避免出现移动端下代码块超出屏幕的情况。
  • 如果自定义了Highlight.js的主题,需要检查主题中是否已经设置了相关的溢出样式,避免我们的自定义样式被主题样式覆盖。

Highlight.js长代码行溢出代码换行前端样式white_space修改时间:2026-07-02 19:42:33

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。