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

本文介绍了如何在Vue项目中利用vue-prism-editor插件实现代码块的语法高亮和编辑模式,包括安装步骤、配置方法及常见问题解决方案。确保了代码的可读性和可编辑性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

需求:

55469409901664bf9c3304e31328f66b.png

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代码

class="my-editor height-300"

v-model="code"

:highlight="highlighter"

:line-numbers="lineNumbers"

>

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代码

/* 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;

}

注意: css样式必写,不然编辑器没有样式,只是纯白页面展示

“height-300” 是给编辑器设置高度的,高度可自行设置,也可以不设置,这个样式非必需

到这里,功能基本就实现了。

但是在过程中遇到一些问题,这里也一并总结。

问题

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

1ed9179cb4ccd6053b9bad0849463a36.png

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版本不一致

809a1bd89a07bddaf356bfb3e8462792.png

卸载低版本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项目页面嵌入代码块内容请搜索云海天教程以前的文章或继续浏览下面的相关文章希望大家以后多多支持云海天教程!

原文链接:https://blog.csdn.net/weixin_41257563/article/details/109381066

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值