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单元格多列合并的实现
Nov 26 Vue.js
Vue router传递参数并解决刷新页面参数丢失问题
Dec 02 Vue.js
vuex页面刷新导致数据丢失的解决方案
Dec 10 Vue.js
vue+element UI实现树形表格
Dec 29 Vue.js
vue实现倒计时功能
Mar 24 Vue.js
关于vue中如何监听数组变化
Apr 28 Vue.js
一文带你理解vue创建一个后台管理系统流程(Vue+Element)
May 18 Vue.js
Vue实现跑马灯样式文字横向滚动
Nov 23 Vue.js
Vue3中toRef与toRefs的区别
Mar 24 Vue.js
vue组件vue-esign实现电子签名
Apr 21 Vue.js
详解Vue3使用axios的配置教程
Apr 29 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
php页面缓存ob系列函数介绍
2012/10/18 PHP
MacOS 安装 PHP的图片裁剪扩展Tclip
2015/03/25 PHP
如何让PHP编码更加好看利于阅读
2019/05/12 PHP
jquery 选择器部分整理
2009/10/28 Javascript
锋利的jQuery 要点归纳(三) jQuery中的事件和动画(上:事件篇)
2010/03/24 Javascript
Textarea与懒惰渲染实现代码
2012/01/04 Javascript
带左右箭头图片轮播的JS代码
2013/12/18 Javascript
JQuery 实现在同一页面锚点链接之间的平滑滚动
2014/10/29 Javascript
Javascript前端UI框架Kit使用指南之kitjs的对话框组件
2014/11/28 Javascript
深入剖析JavaScript:Object类型
2016/05/10 Javascript
详解vue前后台数据交互vue-resource文档
2017/07/19 Javascript
bootstrap响应式工具使用详解
2017/11/29 Javascript
如何快速解决JS或Jquery ajax异步跨域的问题
2018/01/08 jQuery
RequireJS用法简单示例
2018/08/20 Javascript
使用VueCli3+TypeScript+Vuex一步步构建todoList的方法
2019/07/25 Javascript
移动端手指操控左右滑动的菜单
2019/09/08 Javascript
[01:31]完美与DOTA2历程
2014/07/31 DOTA
[48:35]2018DOTA2亚洲邀请赛 4.1 小组赛 A组加赛 TNC vs Optic
2018/04/03 DOTA
Python元组操作实例分析【创建、赋值、更新、删除等】
2017/07/24 Python
Python实现自动为照片添加日期并分类的方法
2017/09/30 Python
Python实现桶排序与快速排序算法结合应用示例
2017/11/22 Python
python Gabor滤波器讲解
2020/10/26 Python
解决tensorflow模型压缩的问题_踩坑无数,总算搞定
2021/03/02 Python
html5文本内容_动力节点Java学院整理
2017/07/11 HTML / CSS
前端H5 Video常见使用场景简介
2020/08/21 HTML / CSS
凯撒娱乐:Caesars Entertainment
2018/02/23 全球购物
远程教育心得体会
2014/01/03 职场文书
企业安全生产标语
2014/06/06 职场文书
保安2014年终工作总结
2014/12/06 职场文书
学校食品安全责任书
2015/01/29 职场文书
支教个人总结
2015/03/04 职场文书
信用卡工资证明范本
2015/06/19 职场文书
三八节活动主持词
2015/07/04 职场文书
PyCharm 安装与使用配置教程(windows,mac通用)
2021/05/12 Python
Python打包exe时各种异常处理方案总结
2021/05/18 Python
教你用Python爬取英雄联盟皮肤原画
2021/06/13 Python