Prism.js 是最轻量易用的 JavaScript 代码高亮方案,支持丰富语言和主题;需引入核心 CSS 和 JS,代码块须为 结构,按需加载语言或插件,并可手动调用 Prism.highlightAll() 处理动态内容。

JavaScript 实现代码高亮,最轻量、易用且支持丰富的语言和主题的方案之一就是 Prism.js。它不依赖 jQuery,体积小,按需加载语法插件,适合静态页面或现代前端项目。
直接在 HTML 的 <code></code> 或页面底部加入 CDN 链接即可:
<link href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism.min.css" rel="stylesheet">
<script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js"></script>
此时,所有带有 class="xxx" 的 <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false;"><code></code></pre> 结构会自动高亮(如 language-js、language-html)。
Prism 只处理符合约定结构的代码块:
立即学习“Java免费学习笔记(深入)”;
function hello() {
console.log('Hello, Prism!');
}注意要点:
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false;">,内层用 <code></code><code></code> 必须带 class="xxx",比如 language-python、language-bashclass="prism js" 或其他多余 class,除非你自定义了初始化逻辑Prism 默认只包含常用语言。需要 Python、PHP、JSX 等,要额外引入对应语言文件:
<script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/components/prism-python.min.js"></script><link href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/plugins/line-numbers/prism-line-numbers.min.css" rel="stylesheet" /><script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/plugins/line-numbers/prism-line-numbers.min.js"></script><pre class="brush:php;toolbar:false;"> 加 class:<pre class="line-numbers"><code class="js">...如果代码块是 JS 动态生成(比如从 Markdown 渲染后插入),Prism 不会自动处理,需手动调用:
Prism.highlightElement(codeDomNode);
Prism.highlightAll();
推荐在 DOM 插入完成后调用,比如在 setTimeout(() => { Prism.highlightAll(); }, 0) 或 MutationObserver 中使用。
基本上就这些。Prism 上手不复杂但容易忽略结构和加载顺序,按规范写好 HTML + 引对资源,就能稳定工作。
以上就是javascript如何实现代码高亮_Prism.js的基本用法是什么的详细内容,更多请关注php中文网其它相关文章!
java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号