vue集成codemirror代码编辑器
点击上方“
青年码农
”关注
npm install vue-codemirror -S
# yarn
yarn add vue-codemirror -S
<div>
<codemirror
ref="cm"
v-model="value"
:options="options"
@input="inputChange"
> </codemirror>
</div>
</template>
<script>
// 全局引入vue-codemirror
import { codemirror } from "vue-codemirror";
// 引入css文件
import "codemirror/lib/codemirror.css";
// 引入主题 可多个
import "codemirror/theme/ayu-mirage.css";
// 引入语言模式 可多个
import "codemirror/mode/sql/sql.js";
export default {
name: "codemirror",
components: { codemirror },
props: {
value: {
default: ""
}
},
data() {
return {
options: {
// 语言及语法模式
mode: "text/x-sql",
// 主题
theme: "ayu-mirage",
// 显示函数
line: true,
lineNumbers: true,
// 软换行
lineWrapping: true,
// tab宽度
tabSize: 4
}
};
},
methods: {
inputChange(content) {
this.$nextTick(() => {
console.log("content:" + content);
});
}
}
};
</script>
回复“特效源码”可获取各种资料
CodeMirror是一个用 JavaScript 为浏览器实现的通用文本编辑器。它专门用于编辑代码,并带有多种语言模式和插件 ,可实现更高级的编辑功能。
本教程是基于vue2实现集成,使用vue-codemirror插件
1. 安装
npm install vue-codemirror -S
# yarn
yarn add vue-codemirror -S
2. 新建组件并引入
<template> <div>
<codemirror
ref="cm"
v-model="value"
:options="options"
@input="inputChange"
> </codemirror>
</div>
</template>
<script>
// 全局引入vue-codemirror
import { codemirror } from "vue-codemirror";
// 引入css文件
import "codemirror/lib/codemirror.css";
// 引入主题 可多个
import "codemirror/theme/ayu-mirage.css";
// 引入语言模式 可多个
import "codemirror/mode/sql/sql.js";
export default {
name: "codemirror",
components: { codemirror },
props: {
value: {
default: ""
}
},
data() {
return {
options: {
// 语言及语法模式
mode: "text/x-sql",
// 主题
theme: "ayu-mirage",
// 显示函数
line: true,
lineNumbers: true,
// 软换行
lineWrapping: true,
// tab宽度
tabSize: 4
}
};
},
methods: {
inputChange(content) {
this.$nextTick(() => {
console.log("content:" + content);
});
}
}
};
</script>
主题引入多个,我们可以实现动态切换主题,语言模式支持多种语言。
options支持的属性很多,上面的例子只使用了几个常用的属性,更多属性请参照官方文档
https://codemirror.net/doc/manual.html#config
关于如何切换主题和语言模式,通过npm安装的vue-codemirror插件,可以在node_modules中找到codemirror文件夹,你想要的都在这里
只需要引入对应的文件,在options中切换即可。
3.最终效果
本文来自「青年码农」公众号,作者:青年码农,转载请注明原文链接:https://www.cnblogs.com/nmgwap/p/16331556.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)