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验证手机号是否正确实例讲解
Nov 17 Javascript
jQuery中JSONP的两种实现方式详解
Sep 26 Javascript
原生js实现打字动画游戏
Feb 04 Javascript
jQuery基于ajax实现页面加载后检查用户登录状态的方法
Feb 10 Javascript
html+javascript+bootstrap实现层级多选框全层全选和多选功能
Mar 09 Javascript
详解Node全局变量global模块
Sep 28 Javascript
浅谈小程序 setData学问多
Feb 20 Javascript
layui 点击重置按钮, select 并没有被重置的解决方法
Sep 03 Javascript
Vue3.0中的monorepo管理模式的实现
Oct 14 Javascript
微信小程序表单验证WxValidate的使用
Nov 27 Javascript
Vue+ElementUI table实现表格分页
Dec 14 Javascript
小程序点餐界面添加购物车左右摆动动画
Sep 23 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模板类代码
2008/09/07 PHP
PHP 多维数组的排序问题 根据二维数组中某个项排序
2011/11/09 PHP
php从右向左/从左向右截取字符串的实现方法
2011/11/28 PHP
php中判断文件存在是用file_exists还是is_file的整理
2012/09/12 PHP
PHP Swoole异步Redis客户端实现方法示例
2019/10/24 PHP
取得一定长度的内容,处理中文
2006/12/20 Javascript
讲两件事:1.this指针的用法小探. 2.ie的attachEvent和firefox的addEventListener在事件处理上的区别
2007/04/12 Javascript
JavaScript Cookie 直接浏览网站分网址
2009/12/08 Javascript
javascript中自定义对象的属性方法分享
2013/07/12 Javascript
js中parseInt函数浅谈
2013/07/31 Javascript
jquery禁止输入数字以外的字符的示例(纯数字验证码)
2014/04/10 Javascript
jQuery中fadeOut()方法用法实例
2014/12/24 Javascript
js实现Select列表各项上移和下移的方法
2015/08/14 Javascript
jQuery中show与hide方法用法示例
2016/09/16 Javascript
3种不同的ContextMenu右键菜单实现代码
2016/11/03 Javascript
easyui datebox 时间限制,datebox开始时间限制结束时间,datebox截止日期比起始日期大的实现代码
2017/01/12 Javascript
Vue2学习笔记之请求数据交互vue-resource
2017/02/23 Javascript
AngularJS ui-router (嵌套路由)实例
2017/03/10 Javascript
jQuery插件imgAreaSelect基础讲解
2017/05/26 jQuery
Bootstrap输入框组件使用详解
2017/06/09 Javascript
vue-router实现tab标签页(单页面)详解
2017/10/17 Javascript
vue-cli点击实现全屏功能
2020/03/07 Javascript
jQuery实现穿梭框效果
2021/01/19 jQuery
vue前端和Django后端如何查询一定时间段内的数据
2021/02/28 Vue.js
Django + Uwsgi + Nginx 实现生产环境部署的方法
2018/06/20 Python
Python实现string字符串连接的方法总结【8种方式】
2018/07/06 Python
python虚拟环境的安装和配置(virtualenv,virtualenvwrapper)
2019/08/09 Python
如何使用Python脚本实现文件拷贝
2019/11/20 Python
Python使用Numpy模块读取文件并绘制图片
2020/05/13 Python
python实现b站直播自动发送弹幕功能
2021/02/20 Python
The North Face北面英国官网:美国著名户外品牌
2017/12/13 全球购物
教师党员岗位承诺书
2014/05/29 职场文书
校园安全标语
2014/06/07 职场文书
自主招生自荐信范文
2015/03/04 职场文书
超级礼物观后感
2015/06/15 职场文书
营销策划分析:怎么策划才能更好销量产品?
2019/09/04 职场文书