vue3引入highlight.js进行代码高亮的方法实例


Posted in Vue.js onApril 08, 2022

背景描述:

在项目开发中,经常一些日志预览,还有文件的预览,需要进行代码高亮显示。这样可以让文本内容展示的时候显得更加友好,也便于阅读

效果类似markdown语法的代码高亮,如下:

<TestPlan guiclass="TestPlanGui" testclass="TestPlan" testname="自动化测试">
      <stringProp name="TestPlan.comments"></stringProp>
      <boolProp name="TestPlan.functional_mode">false</boolProp>
      <boolProp name="TestPlan.tearDown_on_shutdown">true</boolProp>
      <boolProp name="TestPlan.serialize_threadgroups">false</boolProp>
      <elementProp name="TestPlan.user_defined_variables" elementType="Arguments">
        <collectionProp name="Arguments.arguments"/>
      </elementProp>
    </TestPlan>

一、安装依赖:

注意:我们需要安装的依赖有两个,网上的博文,都是写的一个,比较坑。
npm install --save highlight.js
npm install --save @highlightjs/vue-plugin
命令行如下

## 这个是highlight.js基础依赖
npm install --save highlight.js
## 安装支持vue3 的@highlightjs/vue-plugin 依赖
npm install --save @highlightjs/vue-plugin

二、在vue3主入口main文件,对highlight进行引入和注册:

需要引入的有

样式 ,在main主入口引入样式为全局统一都使用这个样式,也可以在单独的页面引入,你想要的样式。样式效果参考官网:https://highlightjs.org/static/demo/
更改 import ‘highlight.js/styles/atom-one-dark.css’ 把styles 后面的值改成你想要的样式就行依赖包组件
# --- 文件src/main.ts | src/main.js 
# highlight 的样式,依赖包,组件
import 'highlight.js/styles/atom-one-dark.css'
import 'highlight.js/lib/common'
import hljsVuePlugin from '@highlightjs/vue-plugin'

import { computed, createApp } from 'vue'
import App from './App.vue'

const app = createApp(App)

// 引入代码高亮,并进行全局注册
app.use(hljsVuePlugin)
app.mount('#app')

三、页面使用:

<!-- 把数据绑定到 `code` 属性-->
    <highlightjs autodetect :code="code" />
    <!--或者直接将显示的代码写到 `code`中 -->
    <highlightjs language='javascript' code="var x = 5;" />

示例如下:
可以使用 language 指定具体的语言,如javascript、xml等
这个值省略,highlightjs 也会自动识别对应的语言
vue3引入highlight.js进行代码高亮的方法实例

四、看下效果展示吧:

vue3引入highlight.js进行代码高亮的方法实例

vue3引入highlight.js进行代码高亮的方法实例

五、一些优化:

1.问题

可以看到生成的代码 是pre包裹的,会有个1rem 的margin-bottom,效果不是很好
vue3引入highlight.js进行代码高亮的方法实例

2.解决方法

在对应的页面,使用style 标签,对样式进行重写,注意不要加 scoped

<style lang="scss">
pre {
  margin-bottom: 0;
}
</style>

vue3引入highlight.js进行代码高亮的方法实例

3. 处理后的效果

这个是示例,当然你们可以根据实际的项目进行样式改造
码字不容易,对你有帮助的话,给个点赞吧 ☻ (✿◠‿◠)
更多详情,请查阅官方文档,
官网链接:https://highlightjs.org/
官网github链接:https://github.com/highlightjs/vue-plugin

vue3引入highlight.js进行代码高亮的方法实例

总结

到此这篇关于vue3引入highlight.js进行代码高亮例的文章就介绍到这了,更多相关vue3引入highlight.js代码高亮内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Vue.js 相关文章推荐
vue-calendar-component 封装多日期选择组件的实例代码
Dec 04 Vue.js
全面解析Vue中的$nextTick
Dec 24 Vue.js
vue项目中openlayers绘制行政区划
Dec 24 Vue.js
WebStorm无法正确识别Vue3组合式API的解决方案
Feb 18 Vue.js
详解Vue的options
May 15 Vue.js
vue-cropper插件实现图片截取上传组件封装
May 27 Vue.js
详解Vue项目的打包方式(生成dist文件)
Jan 18 Vue.js
vue实力踩坑之push当前页无效
Apr 10 Vue.js
vue封装数字翻牌器
Apr 20 Vue.js
vue elementUI批量上传文件
Apr 26 Vue.js
Vue ECharts实现机舱座位选择展示功能
May 15 Vue.js
vue el-table实现递归嵌套的示例代码
Aug 14 Vue.js
vue中的可拖拽宽度div的实现示例
vue 实现弹窗关闭后刷新效果
Apr 08 #Vue.js
vue中this.$http.post()跨域和请求参数丢失的解决
Apr 08 #Vue.js
vue实现书本翻页动画效果实例详解
Apr 08 #Vue.js
vue实现列表拖拽排序的示例代码
vue实现可以快进后退的跑马灯组件
Apr 08 #Vue.js
Axios代理配置及封装响应拦截处理方式
You might like
Laravel框架使用monolog_mysql实现将系统日志信息保存到mysql数据库的方法
2018/08/16 PHP
PHP让网站移动访问更加友好方法
2019/02/14 PHP
javascript下arguments,caller,callee,call,apply示例及理解
2009/12/24 Javascript
JavaScript动态改变表格单元格内容的方法
2015/03/30 Javascript
jquery使用经验小结
2015/05/20 Javascript
原生js仿jquery实现对Ajax的封装
2016/10/04 Javascript
JS实现JSON.stringify的实例代码讲解
2017/02/07 Javascript
jQuery插件FusionCharts实现的MSBar2D图效果示例【附demo源码】
2017/03/24 jQuery
jQuery之动画ajax事件(实例讲解)
2017/07/18 jQuery
vue实现手机号码抽奖上下滚动动画示例
2017/10/18 Javascript
React Native 搭建开发环境的方法步骤
2017/10/30 Javascript
jquery动态添加带有样式的HTML标签元素方法
2018/02/24 jQuery
详解如何使用router-link对象方式传递参数?
2019/05/02 Javascript
微信小程序的开发范式BeautyWe.js入门详解
2019/07/10 Javascript
[14:00]DOTA2国际邀请赛史上最长大战 赛后专访B神
2013/08/10 DOTA
[53:15]2018DOTA2亚洲邀请赛3月29日 小组赛A组 LGD VS TNC
2018/03/30 DOTA
[01:11:35]Liquid vs LGD 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
Python实现的一个自动售饮料程序代码分享
2014/08/25 Python
python通过正则查找微博@(at)用户的方法
2015/03/13 Python
Python实现统计文本文件字数的方法
2017/05/05 Python
Python数据结构与算法之常见的分配排序法示例【桶排序与基数排序】
2017/12/15 Python
Python3中列表list合并的四种方法
2019/04/19 Python
Python 字节流,字符串,十六进制相互转换实例(binascii,bytes)
2020/05/11 Python
pandas参数设置的实用小技巧
2020/08/23 Python
pip/anaconda修改镜像源,加快python模块安装速度的操作
2021/03/04 Python
html5移动端自适应布局的实现
2020/04/15 HTML / CSS
Clarks鞋法国官方网站:英国其乐鞋品牌
2018/02/11 全球购物
100%有机精油,美容油:House of Pure Essence
2018/10/30 全球购物
Myprotein芬兰官网:欧洲第一运动营养品牌
2019/05/05 全球购物
国际贸易专业个人求职信范文分享
2013/12/14 职场文书
二十年同学聚会致辞
2015/07/28 职场文书
导游词之青城山景区
2019/09/27 职场文书
Python数据分析之pandas函数详解
2021/04/21 Python
TensorFlow的自动求导原理分析
2021/05/26 Python
手写实现JS中的new
2021/11/07 Javascript
Python中的turtle画箭头,矩形,五角星
2022/03/16 Python