最近需要在一个Vue2(element)网站加一个sql语句输入框供用户输入,尝试使用highlight.js和prisjm.js可以对嵌入代码进行高亮,但无法实现对用户在线输入的代码内容高亮的需求,于是使用了codemirror实现
1.npm下载vue-codemirror
重中之重,下载时注意指定版本,且这里下载vue-codemirror,不是codemirror,两者现有版本不同,可在npm社区查看具体版本,这里我下载的是vue-codemirror4.0.6支持Vue2,默认下载是最新版本只支持Vue3。
cnpm install vue-codemirror@4.0.6
2.在main.js中配置codemirror插件
import VueCodeMirror from 'vue-codemirror'
import 'codemirror/lib/codemirror.css'
Vue.use(VueCodeMirror)
3.在需要使用的vue文件中引入codemirror插件(可根据需求自行选择和配置)
import 'codemirror/mode/sql/sql.js'
// 主题css
import 'codemirror/theme/solarized.css'
// require active-line.js
import 'codemirror/addon/selection/active-line.js&#