[Js]使用highlight.js高亮vue代码

[Js]使用highlight.js高亮vue代码

Vue SFC (.vue) 文件本身是 复合语言,包含 <template><script><style>

所以只使用单语言进行高亮效果很差。

思路是通过工具进行拆分,单部分进行高亮,再通过拆分参数进行整合

  • 高亮使用highlight.js
  • 拆分使用@vue/compiler-sfc

目前粗略的试了下,是可以实现的

示例代码

其中vue3_ts_prefix等几个变量是我提前格式化一遍的,后续等做工具的时候,可以放到逻辑里实现

js 复制代码
import hljs from 'highlight.js/lib/core'
import plaintext from 'highlight.js/lib/languages/plaintext'
import html from 'highlight.js/lib/languages/xml'
import js from 'highlight.js/lib/languages/javascript'
import ts from 'highlight.js/lib/languages/typescript'
import css from 'highlight.js/lib/languages/css'
import { parse } from '@vue/compiler-sfc'

// 注册语言
if (!hljs.getLanguage('plaintext')) hljs.registerLanguage('plaintext', plaintext)
if (!hljs.getLanguage('html')) hljs.registerLanguage('html', html)
if (!hljs.getLanguage('js')) hljs.registerLanguage('js', js)
if (!hljs.getLanguage('ts')) hljs.registerLanguage('ts', ts)
if (!hljs.getLanguage('css')) hljs.registerLanguage('css', css)

const TypeMap: Record<string, string> = {
  html: 'html',
  js: 'js',
  css: 'css'
}

const vue3_ts_prefix =
  '<span class="hljs-tag">&lt;<span class="hljs-name">script</span> <span class="hljs-attr">setup</span> <span class="hljs-attr">lang</span>=<span class="hljs-string">&quot;ts&quot;</span>&gt;</span>'
const vue3_ts_suffix = '<span class="hljs-tag">&lt;/<span class="hljs-name">script</span>&gt;</span>'

const vue3_html_prefix = '<span class="hljs-tag">&lt;<span class="hljs-name">template</span>&gt;</span>'
const vue3_html_suffix = '<span class="hljs-tag">&lt;/<span class="hljs-name">template</span>&gt;</span>'

export const renderCode = (code: string, type: string) => {
  if (type === 'vue3') {
    const { descriptor } = parse(code)
    let text = ''
    if (descriptor.scriptSetup) {
      const t1 = hljs.highlight(descriptor.scriptSetup.content, { language: 'ts' }).value
      text += vue3_ts_prefix + t1 + vue3_ts_suffix
    }
    if (descriptor.template) {
      const t2 = hljs.highlight(descriptor.template.content, { language: 'html' }).value
      if (text) text += '\n\n'
      text += vue3_html_prefix + t2 + vue3_html_suffix
    }
    return text
  }
  const language = TypeMap[type] || 'plaintext'
  return hljs.highlight(code, { language }).value
}
使用效果
相关推荐
子兮曰6 小时前
Bun v1.3.14 深度解析:Image API、HTTP/3、全局虚拟存储与五十项变革
前端·后端·bun
kyriewen7 小时前
今天,百年巨头一次砍了9200人,而一个离职科学家的实话让全网睡不着觉
前端·openai·ai编程
问心无愧05137 小时前
ctf show web 入门42
android·前端·android studio
kyriewen8 小时前
老板逼我上AI,我偷偷在浏览器里跑LLaMA,省下20万API费
前端·react.js·llm
Beginner x_u8 小时前
前端八股整理(手写 02)|数组转树、数组扁平化、随机打乱一个数组
前端·数组·数组转树·数组扁平化
KaMeidebaby8 小时前
卡梅德生物技术快报|禽类成纤维细胞 FISH 实验:鸟类性别染色体基因定位技术实现与数据验证
前端·数据库·其他·百度·新浪微博
天若有情6738 小时前
前端高阶性能优化:跳出传统懒加载与预加载,基于用户行为做轻量预判加载
前端·性能优化
小小小小宇8 小时前
前端转后端:SQL 是什么
前端
张元清9 小时前
React Observer Hooks:7 种监听 DOM 而不写样板代码的方式
前端·javascript·面试
广州华水科技9 小时前
单北斗GNSS变形监测是什么?主要有怎样的应用与优势?
前端