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中通过render函数给子组件设置ref操作
Nov 17 Vue.js
vue自定义插件封装,实现简易的elementUi的Message和MessageBox的示例
Nov 20 Vue.js
vue单元格多列合并的实现
Nov 26 Vue.js
vue+element实现动态加载表单
Dec 13 Vue.js
vue keep-alive的简单总结
Jan 25 Vue.js
关于vue中如何监听数组变化
Apr 28 Vue.js
深入理解Vue的数据响应式
May 15 Vue.js
vue2实现provide inject传递响应式
May 21 Vue.js
Vue3.0 手写放大镜效果
Jul 25 Vue.js
Vue h函数的使用详解
Feb 18 Vue.js
vue+echarts实现多条折线图
Mar 21 Vue.js
Vue.Draggable实现交换位置
Apr 07 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
便携利器 — TECSUN PL-365简评
2021/03/02 无线电
PHP学习之PHP运算符
2006/10/09 PHP
php的array_multisort()使用方法介绍
2012/05/16 PHP
CentOS6.5 编译安装lnmp环境
2014/12/21 PHP
Laravel框架实现发送短信验证功能代码
2016/06/06 PHP
thinkphp跨库操作的简单代码实例
2016/09/22 PHP
Aster vs Newbee BO3 第二场2.18
2021/03/10 DOTA
用javascript实现改变TEXTAREA滚动条和按钮的颜色,以及怎样让滚动条变得扁平
2007/04/20 Javascript
两个DIV等高的JS的实现代码
2007/12/23 Javascript
jQuery 回调函数(callback)的使用和基础
2015/02/26 Javascript
JavaScript中使用自然对数ln的方法
2015/06/14 Javascript
javascript实现手机震动API代码
2015/08/05 Javascript
Boostrap基础教程之JavaScript插件篇
2016/09/08 Javascript
详解AngularJs中$resource和restfu服务端数据交互
2016/09/21 Javascript
ASP.NET jquery ajax传递参数的实例
2016/11/02 Javascript
JS实现密码框的显示密码和隐藏密码功能示例
2016/12/26 Javascript
借助node实战JSONP跨域实例
2017/03/30 Javascript
vue前后分离调起微信支付
2019/07/29 Javascript
基于JavaScript或jQuery实现网站夜间/高亮模式
2020/05/30 jQuery
使用TS来编写express服务器的方法步骤
2020/10/29 Javascript
Python3.0与2.X版本的区别实例分析
2014/08/25 Python
在Windows服务器下用Apache和mod_wsgi配置Python应用的教程
2015/05/06 Python
Python使用struct处理二进制的实例详解
2017/09/11 Python
Python机器学习之SVM支持向量机
2017/12/27 Python
详解Django的CSRF认证实现
2018/10/09 Python
利用python GDAL库读写geotiff格式的遥感影像方法
2018/11/29 Python
解决python3中的requests解析中文页面出现乱码问题
2019/04/19 Python
使用python获取邮箱邮件的设置方法
2019/09/20 Python
Python实现自动打开电脑应用的示例代码
2020/04/17 Python
华为慧通面试题
2012/09/11 面试题
如何写一个自定义标签
2012/12/28 面试题
个人简历中的自我评价范例
2013/10/29 职场文书
运动会通讯稿150字
2014/02/15 职场文书
大学毕业生个人自荐书
2014/07/02 职场文书
应届毕业生求职信范文
2014/07/07 职场文书
2014年安全生产责任书
2014/07/22 职场文书