vue3中使用highlight.js實(shí)現(xiàn)代碼高亮顯示的代碼示例
1.highlight簡(jiǎn)介
Internet 上最受歡迎的 JavaScript 語(yǔ)法高亮工具,支持 Node.js 和 Web。
- 192 種語(yǔ)言和 498 個(gè)主題
- 自動(dòng)語(yǔ)言檢測(cè)
- 適用于任何 HTML 標(biāo)記
- 零依賴
- 兼容任何 JS 框架
- 支持 Node.js 和 Deno
它里面有多種代碼顯示主題可供切換
具體可參考官方文檔:highlight.js中文網(wǎng)
2.vue中的配置與使用
2.1 npm 下載highlight庫(kù)
npm install highlight.js
npm install --save @highlightjs/vue-plugin
2.2 在main.js文件中引入highlight庫(kù)并進(jìn)行注冊(cè)
// 主題樣式 import 'highlight.js/styles/atom-one-dark.css' import 'highlight.js/lib/common' import hljsVuePlugin from '@highlightjs/vue-plugin' //注冊(cè)組件 const app = createApp(App) app.use(hljsVuePlugin) app.mount('#app')
3 在頁(yè)面中使用
3.1 直接在template中使用在main.js中注冊(cè)的組件
<template> <highlightjs language="JavaScript" :autodetect="true" :code="code"></highlightjs> </template> <script setup> let code = `<div>npm install --save highlight.js</div>` </script>
運(yùn)行效果如下:
3.2 純文本代碼展示
使用<pre><code></code></pre>標(biāo)簽包裹代碼文本
<template> <div v-html="message" class="content"></div> </template> <script setup> import hljs from 'highlight.js'; // 引入組件樣式 // import 'highlight.js/styles/default.css'; // import "highlight.js/styles/a11y-dark.css"; import "highlight.js/styles/atom-one-dark-reasonable.css"; import { ref, nextTick, watch, onMounted } from 'vue'; const message = ref(''); const codeContent = ref(''); onMounted(() => { renderCode(); nextTick(() => { handleButtonClick(); }); }); const renderCode = () => { // 需要展示的代碼的純文本 const codeMsg = "javascript\n// 這是一個(gè)簡(jiǎn)單的 JavaScript 代碼示例\nfunction sayHello() {\n console.log(\"Hello, World!\");\n}\n\n// 調(diào)用函數(shù)\nsayHello();\n" // 去除字符串首尾的空格和空白字符串等 codeContent.value = codeMsg.trim(); const highlightedCode = hljs.highlightAuto(codeContent.value).value; message.value = `<pre style="margin-top: 10px;margin-bottom: 10px;position: relative;border-radius:8px;"><button style="position: absolute;top: 10px;right: 10px;cursor: pointer;" id='code'>復(fù)制</button><code style="border-radius:8px;" class="hljs">${highlightedCode}</code></pre>` // console.log(message.value,123); } // 添加點(diǎn)擊事件 const handleButtonClick = () => { let button = document.getElementById(`code`); console.log(button,123121); if (button) { button.addEventListener('click', () => { copyCode(codeContent.value); }); } }; // 點(diǎn)擊復(fù)制代碼 const copyCode = (codeContent) => { navigator.clipboard.writeText(codeContent).then(() => { console.log('復(fù)制成功'); alert('復(fù)制成功'); // ElMessage.success('復(fù)制成功'); }).catch((error) => { console.error('復(fù)制失敗:', error); }); }; </script> <style scoped> .content{ line-height: 30px; font-size: 16px; font-weight: 400; color: #333; word-break: break-all; white-space: pre-wrap; margin-bottom: 5px; } </style>
運(yùn)行效果如下
該js庫(kù)中包含多種代碼顯示主題,可在不同使用的組件中引入不同的主體樣式,以上是一個(gè)簡(jiǎn)單的示例,具體使用請(qǐng)參考Highlight.js 文檔:Highlight.js — highlight.js 11.9.0 文檔
總結(jié)
到此這篇關(guān)于vue3中使用highlight.js實(shí)現(xiàn)代碼高亮顯示的文章就介紹到這了,更多相關(guān)vue3 highlight.js代碼高亮顯示內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue實(shí)現(xiàn)純前端表格滾動(dòng)分頁(yè)加載
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)純前端表格滾動(dòng)分頁(yè)加載,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04Vite內(nèi)網(wǎng)ip訪問(wèn)2種配置方式
這篇文章主要給大家介紹了關(guān)于Vite內(nèi)網(wǎng)ip訪問(wèn)的2種配置方式,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Vite具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2023-07-07Vue與React的區(qū)別和優(yōu)勢(shì)對(duì)比
這篇文章主要介紹了Vue與React的區(qū)別和優(yōu)勢(shì)對(duì)比,幫助大家更好的選擇適合自己的前端框架,迷茫的同學(xué)可以進(jìn)來(lái)參考下2020-12-12Vue3+Vite項(xiàng)目中引入pinia和pinia-plugin-persistedstate的方法代碼
這篇文章主要給大家介紹了關(guān)于Vue3+Vite項(xiàng)目中引入pinia和pinia-plugin-persistedstate的相關(guān)資料,Pinia是Vue.js的官方狀態(tài)管理庫(kù),輕量且功能強(qiáng)大,支持模塊化和TypeScript,PiniaPluginPersistedState是一個(gè)插件,需要的朋友可以參考下2024-11-11淺談Vue為什么不能檢測(cè)數(shù)組變動(dòng)
這篇文章主要介紹了淺談Vue為什么不能檢測(cè)數(shù)組變動(dòng),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10vue導(dǎo)入.md文件的步驟(markdown轉(zhuǎn)HTML)
這篇文章主要介紹了vue導(dǎo)入.md文件的步驟(markdown轉(zhuǎn)HTML),幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下2020-12-12詳解vue項(xiàng)目中如何引入全局sass/less變量、function、mixin
這篇文章主要介紹了詳解vue項(xiàng)目中如何引入全局sass/less變量、function、mixin,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-06-06vue不用import直接調(diào)用實(shí)現(xiàn)接口api文件封裝
這篇文章主要為大家介紹了vue不用import直接調(diào)用實(shí)現(xiàn)接口api文件封裝,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06Vue.js實(shí)現(xiàn)的購(gòu)物車功能詳解
這篇文章主要介紹了Vue.js實(shí)現(xiàn)的購(gòu)物車功能,結(jié)合實(shí)例形式分析了vue.js購(gòu)物車的原理、數(shù)值計(jì)算及頁(yè)面元素屬性動(dòng)態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2019-01-01