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 相关文章推荐
jQuery 名称冲突的解决方法
Apr 08 Javascript
Javascript实现颜色rgb与16进制转换的方法
Apr 18 Javascript
javascript点击按钮实现隐藏显示切换效果
Feb 03 Javascript
javascript实现仿百度图片的瀑布流加载效果
Apr 20 Javascript
jQuery实现调整表格单列顺序完整实例
Jun 20 Javascript
浅谈JS正则表达式的RegExp对象和括号的使用
Jul 28 Javascript
vue-resource 拦截器使用详解
Feb 21 Javascript
AngularJS 最常用的八种功能(基础知识)
Jun 26 Javascript
ES6中Symbol、Set和Map用法详解
Aug 20 Javascript
在layer弹层layer.prompt中,修改placeholder的实现方法
Sep 27 Javascript
Vue scoped及deep使用方法解析
Aug 01 Javascript
JS实现简单的九宫格抽奖
Jun 28 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
新的一年,新的期待:DC在2020年的四部动画电影
2020/01/01 欧美动漫
PHP使用内置dir类实现目录遍历删除
2015/03/31 PHP
php通过exif_read_data函数获取图片的exif信息
2015/05/21 PHP
PHP和MYSQL实现分页导航思路详解
2017/04/11 PHP
基于Jquery的简单&amp;简陋Tabs插件代码
2010/02/09 Javascript
ext jquery 简单比较
2010/04/07 Javascript
基于jquery的button默认enter事件(回车事件)。
2011/05/18 Javascript
Javascript绝句欣赏 一些经典的js代码
2012/02/22 Javascript
js 利用image对象实现图片的预加载提高访问速度
2013/03/29 Javascript
今天是星期几的4种JS代码写法
2013/09/17 Javascript
JavaScript 获取任一float型小数点后两位的小数
2014/06/30 Javascript
JavaScript Math.ceil 方法(对数值向上取整)
2015/01/09 Javascript
jquery通过load获取文件的内容并跳到锚点的方法
2015/01/29 Javascript
Jquery插件实现点击获取验证码后60秒内禁止重新获取
2015/03/13 Javascript
原生JS实现美图瀑布流布局赏析
2015/09/07 Javascript
javascript实现添加附件功能的方法
2015/11/18 Javascript
js正则表达式replace替换变量方法
2016/05/21 Javascript
JavaScript获取IP获取的是IPV6 如何校验
2016/06/12 Javascript
JS实现队列的先进先出功能示例
2017/05/10 Javascript
详解用webpack的CommonsChunkPlugin提取公共代码的3种方式
2017/11/09 Javascript
jQuery使用$.extend(true,object1, object2);实现深拷贝对象的方法分析
2019/03/06 jQuery
[02:08]什么藏在DOTA2 TI9“小紫本”里?斧王历险记告诉你!
2019/05/17 DOTA
python的迭代器与生成器实例详解
2014/07/16 Python
简单介绍Python的Django框架的dj-scaffold项目
2015/05/30 Python
django js实现部分页面刷新的示例代码
2018/05/28 Python
python的pytest框架之命令行参数详解(下)
2019/06/27 Python
Python对接六大主流数据库(只需三步)
2019/07/31 Python
Python使用Pandas库常见操作详解
2020/01/16 Python
Python2与Python3关于字符串编码处理的差别总结
2020/09/07 Python
通用求职信范文模板分享
2013/12/27 职场文书
机关党总支领导班子整改方案
2014/09/20 职场文书
学生自我评语
2015/01/04 职场文书
企业财务人员岗位职责
2015/04/14 职场文书
预备党员转正党小组意见
2015/06/01 职场文书
Python快速实现一键抠图功能的全过程
2021/06/29 Python
keepalived + nginx 实现高可用方案
2022/12/24 Servers