vue项目页面嵌入代码块vue-prism-editor的实现


Posted in Javascript onOctober 30, 2020

需求:

vue项目页面嵌入代码块vue-prism-editor的实现

1. 可输入代码,并且代码语法高亮
2. 支持编辑和不可编辑模式
3. 提交到后端到代码内容为字符串格式

实现

在gitbug上找到vue-prism-editor,可以满足以上需求。

使用

1.安装vue-prism-editor

npm install vue-prism-editor

由于vue-prism-editor需要依赖 prismjs,所以还需要安装prismjs

npm install prismjs

2.在需要使用vue-prism-editor的组件中引入

import { PrismEditor } from "vue-prism-editor";
import "vue-prism-editor/dist/prismeditor.min.css"; // import the styles somewhere

// import highlighting library (you can use any library you want just return html string)
import { highlight, languages } from "prismjs/components/prism-core";
import "prismjs/components/prism-clike";
import "prismjs/components/prism-javascript";
import "prismjs/themes/prism-tomorrow.css"; // import syntax highlighting styles

3.html代码

<prism-editor
 class="my-editor height-300"
 v-model="code"
 :highlight="highlighter"
 :line-numbers="lineNumbers"
></prism-editor>

code----为需要高亮显示的代码内容
highlighter----定义在methods中的一个方法,用于把code高亮显示
lineNumbers----是否可编辑标识

4.js代码

export default {
 components: {
 PrismEditor
 },
 data: () => ({
 code: 'console.log("Hello World")',
 lineNumbers: true, // true为编辑模式, false只展示不可编辑
 }),
 methods: {
 highlighter(code) {
 return highlight(code, languages.js); //returns html
 }
 }
};

5.css代码

<style lang="scss">
/* required class */
.my-editor {
 background: #2d2d2d;
 color: #ccc;

 font-family: Fira code, Fira Mono, Consolas, Menlo, Courier, monospace;
 font-size: 14px;
 line-height: 1.5;
 padding: 5px;
}

/* optional */
.prism-editor__textarea:focus {
 outline: none;
}

/* not required: */
.height-300 {
 height: 300px;
}
</style>

注意: css样式必写,不然编辑器没有样式,只是纯白页面展示
“height-300” 是给编辑器设置高度的,高度可自行设置,也可以不设置,这个样式非必需

到这里,功能基本就实现了。
但是在过程中遇到一些问题,这里也一并总结。

问题

1.如果仅安装vue-prism-editor,没有安装prismjs,会报以下错误,npm install prismjs即可

vue项目页面嵌入代码块vue-prism-editor的实现

2.如果报错中有提示升级或者安装ajv或者vue2.6.X版本,根据提示安装即可

npm install ajv@^6.9.1
npm install vue@^2.6.11

个人理解,如果ajv和vue版本过低,可能会导致vue-prism-editor依赖的相关东西安装不上,建议升级完ajv和vue之后,再重新安装vue-prism-editor和prismjs.

3.vue与vue-template-compiler版本不一致

vue项目页面嵌入代码块vue-prism-editor的实现

卸载低版本vue-template-compiler

npm uninstall vue-template-compiler

然后安装跟vue同样版本的vue-template-compiler

npm install vue-template-compiler@2.6.11

到此这篇关于vue项目页面嵌入代码块vue-prism-editor的文章就介绍到这了,更多相关vue项目页面嵌入代码块内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
Javascript常考语句107条收集
Mar 09 Javascript
JS可以控制样式的名称写法一览
Jan 16 Javascript
使用 js+正则表达式为关键词添加链接
Nov 11 Javascript
jquery实现页面百叶窗走马灯式翻滚显示效果的方法
Mar 12 Javascript
JS动态添加的div点击跳转到另一页面实现代码
Sep 30 Javascript
AngularJS监听ng-repeat渲染完成的方法
Mar 20 Javascript
vue富文本编辑器组件vue-quill-edit使用教程
Sep 21 Javascript
微信小程序实现自动定位功能
Oct 31 Javascript
Vue 指令实现按钮级别权限管理功能
Apr 23 Javascript
改进 JavaScript 和 Rust 的互操作性并深入认识 wasm-bindgen 组件
Jul 13 Javascript
node.js中fs文件系统模块的使用方法实例详解
Feb 13 Javascript
Vue动态加载图片在跨域时无法显示的问题及解决方法
Mar 10 Javascript
解决vue侦听器watch,调用this时出现undefined的问题
Oct 30 #Javascript
vue2.0 watch里面的 deep和immediate用法说明
Oct 30 #Javascript
JavaScript实现轮播图效果
Oct 30 #Javascript
vue组件添加事件@click.native操作
Oct 30 #Javascript
解决removeEventListener 无法清除监听的问题
Oct 30 #Javascript
详解 javascript对象创建模式
Oct 30 #Javascript
ES6中的Javascript解构的实现
Oct 30 #Javascript
You might like
PHP写杨辉三角实例代码
2011/07/17 PHP
如何使用Linux的Crontab定时执行PHP脚本的方法
2011/12/19 PHP
解析将多维数组转换为支持curl提交的一维数组格式
2013/07/08 PHP
php限制上传文件类型并保存上传文件的方法
2015/03/13 PHP
PHP数组编码gbk与utf8互相转换的两种方法
2016/09/01 PHP
js加载之使用DOM方法动态加载Javascript文件
2013/11/08 Javascript
jQuery设置与获取HTML,文本和值的简单实例
2014/02/26 Javascript
jquery控制显示服务器生成的图片流
2015/08/04 Javascript
jQuery插件实现无缝滚动特效
2015/11/24 Javascript
AngularJS 中的指令实践开发指南(一)
2016/03/20 Javascript
浅谈Node.js轻量级Web框架Express4.x使用指南
2017/05/03 Javascript
Layui数据表格之单元格编辑方式
2019/10/26 Javascript
[46:32]Fnatic vs OG 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
[01:03]PWL开团时刻DAY6——别打我
2020/11/05 DOTA
解决Django加载静态资源失败的问题
2019/07/28 Python
pytorch实现Tensor变量之间的转换
2020/02/17 Python
Python读入mnist二进制图像文件并显示实例
2020/04/24 Python
浅谈pycharm导入pandas包遇到的问题及解决
2020/06/01 Python
keras自动编码器实现系列之卷积自动编码器操作
2020/07/03 Python
带你认识HTML5中的WebSocket
2015/05/22 HTML / CSS
德国黑胶唱片、街头服装及运动鞋网上商店:HHV
2018/08/24 全球购物
什么是唯一索引
2015/07/05 面试题
自我鉴定的范文
2013/10/03 职场文书
摄影展策划方案
2014/06/02 职场文书
汉语专业毕业生自荐信
2014/07/06 职场文书
医德考评自我评价
2014/09/14 职场文书
2014年九一八事变演讲稿
2014/09/14 职场文书
党员国庆节演讲稿范文2014
2014/09/21 职场文书
2015清明节祭奠英烈寄语大全
2015/03/04 职场文书
应届生简历自我评价
2015/03/11 职场文书
网站文案策划岗位职责
2015/04/14 职场文书
2015年商场工作总结
2015/04/27 职场文书
开学典礼观后感
2015/06/15 职场文书
麦田里的守望者读书笔记
2015/06/30 职场文书
导游词之上海杜莎夫人蜡像馆
2019/11/22 职场文书
springboot应用服务启动事件的监听实现
2022/04/06 Java/Android