欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3中使用highlight.js實現(xiàn)代碼高亮顯示的代碼示例

 更新時間:2025年04月10日 10:16:09   作者:魚魚魚-YYY  
代碼高亮是在網(wǎng)頁開發(fā)中常見的需求之一,它可以使代碼在頁面上以不同的顏色或樣式進行突出顯示提高可讀性,這篇文章主要介紹了vue3中使用highlight.js實現(xiàn)代碼高亮顯示的相關資料,需要的朋友可以參考下

1.highlight簡介

Internet 上最受歡迎的 JavaScript 語法高亮工具,支持 Node.js 和 Web。

  • 192 種語言和 498 個主題
  • 自動語言檢測
  • 適用于任何 HTML 標記
  • 零依賴
  • 兼容任何 JS 框架
  • 支持 Node.js 和 Deno

它里面有多種代碼顯示主題可供切換

具體可參考官方文檔:highlight.js中文網(wǎng)

2.vue中的配置與使用

2.1 npm 下載highlight庫 

npm install highlight.js
npm install --save @highlightjs/vue-plugin

2.2 在main.js文件中引入highlight庫并進行注冊

// 主題樣式
import 'highlight.js/styles/atom-one-dark.css'
import 'highlight.js/lib/common'
import hljsVuePlugin from '@highlightjs/vue-plugin'
 
//注冊組件
const app = createApp(App)

app.use(hljsVuePlugin)
app.mount('#app')

3 在頁面中使用

3.1 直接在template中使用在main.js中注冊的組件

<template>
  <highlightjs language="JavaScript" :autodetect="true" :code="code"></highlightjs>
</template>

<script setup>
  let code = `<div>npm install --save highlight.js</div>`
</script>

運行效果如下:

3.2 純文本代碼展示

使用<pre><code></code></pre>標簽包裹代碼文本

<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// 這是一個簡單的 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'>復制</button><code style="border-radius:8px;" class="hljs">${highlightedCode}</code></pre>`

//     console.log(message.value,123);
    
}

// 添加點擊事件
const handleButtonClick = () => {
    let button = document.getElementById(`code`);
    console.log(button,123121);
    
    if (button) {
        button.addEventListener('click', () => {
            copyCode(codeContent.value);
        });
    }
};

// 點擊復制代碼
const copyCode = (codeContent) => {
    
    navigator.clipboard.writeText(codeContent).then(() => {
      console.log('復制成功');
      alert('復制成功');
    //   ElMessage.success('復制成功');
    }).catch((error) => {
      console.error('復制失敗:', 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>

運行效果如下

該js庫中包含多種代碼顯示主題,可在不同使用的組件中引入不同的主體樣式,以上是一個簡單的示例,具體使用請參考Highlight.js 文檔Highlight.js — highlight.js 11.9.0 文檔

總結

到此這篇關于vue3中使用highlight.js實現(xiàn)代碼高亮顯示的文章就介紹到這了,更多相關vue3 highlight.js代碼高亮顯示內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • vue實現(xiàn)純前端表格滾動分頁加載

    vue實現(xiàn)純前端表格滾動分頁加載

    這篇文章主要為大家詳細介紹了vue實現(xiàn)純前端表格滾動分頁加載,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • Vite內(nèi)網(wǎng)ip訪問2種配置方式

    Vite內(nèi)網(wǎng)ip訪問2種配置方式

    這篇文章主要給大家介紹了關于Vite內(nèi)網(wǎng)ip訪問的2種配置方式,文中通過實例代碼介紹的非常詳細,對大家學習或者使用Vite具有一定的參考學習價值,需要的朋友可以參考下
    2023-07-07
  • Vue與React的區(qū)別和優(yōu)勢對比

    Vue與React的區(qū)別和優(yōu)勢對比

    這篇文章主要介紹了Vue與React的區(qū)別和優(yōu)勢對比,幫助大家更好的選擇適合自己的前端框架,迷茫的同學可以進來參考下
    2020-12-12
  • Vue3+Vite項目中引入pinia和pinia-plugin-persistedstate的方法代碼

    Vue3+Vite項目中引入pinia和pinia-plugin-persistedstate的方法代碼

    這篇文章主要給大家介紹了關于Vue3+Vite項目中引入pinia和pinia-plugin-persistedstate的相關資料,Pinia是Vue.js的官方狀態(tài)管理庫,輕量且功能強大,支持模塊化和TypeScript,PiniaPluginPersistedState是一個插件,需要的朋友可以參考下
    2024-11-11
  • 淺談Vue為什么不能檢測數(shù)組變動

    淺談Vue為什么不能檢測數(shù)組變動

    這篇文章主要介紹了淺談Vue為什么不能檢測數(shù)組變動,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-10-10
  • vue導入.md文件的步驟(markdown轉(zhuǎn)HTML)

    vue導入.md文件的步驟(markdown轉(zhuǎn)HTML)

    這篇文章主要介紹了vue導入.md文件的步驟(markdown轉(zhuǎn)HTML),幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下
    2020-12-12
  • 詳解vue項目中如何引入全局sass/less變量、function、mixin

    詳解vue項目中如何引入全局sass/less變量、function、mixin

    這篇文章主要介紹了詳解vue項目中如何引入全局sass/less變量、function、mixin,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • vue不用import直接調(diào)用實現(xiàn)接口api文件封裝

    vue不用import直接調(diào)用實現(xiàn)接口api文件封裝

    這篇文章主要為大家介紹了vue不用import直接調(diào)用實現(xiàn)接口api文件封裝,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • Vue.js中v-model指令的用法介紹

    Vue.js中v-model指令的用法介紹

    這篇文章介紹了Vue.js中v-model指令的用法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-03-03
  • Vue.js實現(xiàn)的購物車功能詳解

    Vue.js實現(xiàn)的購物車功能詳解

    這篇文章主要介紹了Vue.js實現(xiàn)的購物車功能,結合實例形式分析了vue.js購物車的原理、數(shù)值計算及頁面元素屬性動態(tài)操作相關實現(xiàn)技巧,需要的朋友可以參考下
    2019-01-01

最新評論