基于CodeMirror开发在线编辑器时遇到的问题及解决方案

news/2024/10/14 0:31:01

需求:实现json在线编辑并支持校验,基于此使用了 CodeMirror在线编辑,jsonlint校验输入数据

// package.json:"dependencies": {"codemirror": "^5.53.2","core-js": "^3.8.3","jsonlint": "^1.6.3","vue": "^2.6.14"},

基础代码:

<template><div class="json-editor"><textarea ref="textarea" /></div>
</template><script>
import CodeMirror from "codemirror";
import "codemirror/addon/lint/lint.css";
import "codemirror/lib/codemirror.css";
import "codemirror/theme/rubyblue.css";
import "codemirror/mode/javascript/javascript";
import "codemirror/addon/lint/lint";
import "codemirror/addon/lint/json-lint";
require('script-loader!jsonlint')
export default {name: "JsonEditor", props: ["value"],data() {return {jsonEditor: false,};},watch: {value(value) {const editorValue = this.jsonEditor.getValue();if (value !== editorValue) {this.jsonEditor.setValue(JSON.stringify(this.value, null, 2));}},},mounted() {// CodeMirror.fromTextArea()中第一个参数是DOM元素,而且必须是textarea元素;第二个参数是可选配置项this.jsonEditor = CodeMirror.fromTextArea(this.$refs.textarea, {lineNumbers: true,mode: "application/json",gutters: ["CodeMirror-lint-markers"],theme: "rubyblue",lint: true,lineWrapping: true, // 自动换行scrollPastEnd: true, // 允许用户将一个编辑器高度的空白区域滚动到编辑器底部的视图lineNumbers: true, // 显示左边行号(默认false,即不显示)styleActiveLine: true, // 当前行背景高亮});this.jsonEditor.setValue(JSON.stringify(this.value, null, 2));this.jsonEditor.on("change", (cm) => {console.log("cm.getValue() :>> ", cm.getValue());this.$emit("changed", cm.getValue());this.$emit("input", cm.getValue());});},methods: {getValue() {return this.jsonEditor.getValue();},},
};
</script><style scoped>
.json-editor {height: 100%;position: relative;
}
.json-editor >>> .CodeMirror {height: auto;min-height: 300px;
}
.json-editor >>> .CodeMirror-scroll {min-height: 300px;
}
.json-editor >>> .cm-s-rubyblue span.cm-string {color: #f08047;
}
.addbtn {margin-bottom: 15px;margin-left: 30px;
}
</style>

这样,他就成功的报错了!
报错原因是因为这一行:require('script-loader!jsonlint')
项目找不到script-loader,因而下了一个:

npm install script-loader

下载完毕,项目就有了雏形:

但是估计错误输入后发现,并没有实现错误校验功能,很纳闷,明明写了lint:true
然后尝试打开控制台看了下:

json-lint.js:22  Error: window.jsonlint not defined, CodeMirror JSON linting cannot run.

不懂为什么,于是尝试使用import替换require
依旧如此
后来去github翻了下issue, 发现此条可用:
https://github.com/scniro/react-codemirror2/issues/21

须下载jsonlint-mod:

npm install jsonlint-mod

于是便实现了:

完整代码(无坑版):

<template><div class="json-editor"><textarea ref="textarea" /></div>
</template><script>
import CodeMirror from "codemirror";
import "codemirror/addon/lint/lint.css";
import "codemirror/lib/codemirror.css";
import "codemirror/theme/rubyblue.css";
import "codemirror/mode/javascript/javascript";
import "codemirror/addon/lint/lint";
import "codemirror/addon/lint/json-lint";
const jsonlint = require("jsonlint-mod");
console.log('jsonlint :>> ', jsonlint);
window.jsonlint = jsonlint;
export default {name: "JsonEditor", props: ["value"],data() {return {jsonEditor: false,};},watch: {value(value) {const editorValue = this.jsonEditor.getValue();if (value !== editorValue) {this.jsonEditor.setValue(JSON.stringify(this.value, null, 2));}},},mounted() {// CodeMirror.fromTextArea()中第一个参数是DOM元素,而且必须是textarea元素;第二个参数是可选配置项this.jsonEditor = CodeMirror.fromTextArea(this.$refs.textarea, {lineNumbers: true,mode: "application/json",gutters: ["CodeMirror-lint-markers"],theme: "rubyblue",lint: true,lineWrapping: true, // 自动换行scrollPastEnd: true, // 允许用户将一个编辑器高度的空白区域滚动到编辑器底部的视图lineNumbers: true, // 显示左边行号(默认false,即不显示)styleActiveLine: true, // 当前行背景高亮});this.jsonEditor.setValue(JSON.stringify(this.value, null, 2));this.jsonEditor.on("change", (cm) => {console.log("cm.getValue() :>> ", cm.getValue());this.$emit("changed", cm.getValue());this.$emit("input", cm.getValue());});},methods: {getValue() {return this.jsonEditor.getValue();},},
};
</script><style scoped>
.json-editor {height: 100%;position: relative;
}
.json-editor >>> .CodeMirror {height: auto;min-height: 300px;
}
.json-editor >>> .CodeMirror-scroll {min-height: 300px;
}
.json-editor >>> .cm-s-rubyblue span.cm-string {color: #f08047;
}
.addbtn {margin-bottom: 15px;margin-left: 30px;
}
</style>

以上。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.ryyt.cn/news/26871.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

【VMware vCenter】连接和使用vCenter Server嵌入式vPostgres数据库。

vCenter Server 早期支持内嵌(embedded)和外部(external)数据库,内嵌数据库就是vPostgres,基于VMware Postgres数据库(PostgreSQL数据库),外部数据库用的多的是Oracle数据库和SQL Server数据库。因为早期使用内嵌的PostgreSQL数据库只能用于小型环境,比如仅支持几十台…

对于 CF1107E 中 dp 状态设计的一点想法

我在这延伸谱线誊写勾勒 / 试图将歌唱的意义勘破不太想发到洛谷讨论区,就往这里放了。 我觉得现有的题解都没说明白为什么本题的状态和转移能覆盖所有情况,并且感觉也非常不自然,没见过的话感觉挺难发现这么一个东西。 然而这个 dp 其实是可以自然地推导出来的。 首先发现这…

解决vscode连接远程服务器出现Bad owner or permissions on C:\\Users\\Administrator/.ssh/config 过程试图写入的管道不存在。

1.找到.ssh文件夹。它通常位于C:\Users2.右键单击.ssh文件夹,然后单击“属性”,选择“安全”3.单击“高级”。 单击“禁用继承”,单击“确定”。 将出现警告弹出窗口。单击“从此对象中删除所有继承的权限”。 4.此时所有用户都将被删除。添加所有者。在同一窗口中,单击“编…

TCP的三次握手过程

TCP 是面向连接的、可靠的、基于字节流的传输层通信协议。TCP 是面向连接的协议,所以使用 TCP 前必须先建立连接,而建立连接是通过三次握手来进行的...TCP是面向连接的、可靠的、基于字节流的传输层通信协议。 TCP是面向连接的协议,所以使用 TCP前必须先建立连接,而建立连接…

用 Python 开发一个【GIF表情包制作神器】

用python成为了微信斗图届的高手然后,好多人表示:虽然存了很多表情包但似乎还不是很过瘾因为它不可以自己来定制我们可不可以根据一些表情素材然后自己制作专属表情包呢像这样本来小帅b想自己实现一个表情包制作器后来发现已经有人在 GitHub 分享了 主要功能就是 可以在原有的…

DRM

DRM是Linux目前主流的图形显示框架,相比FB架构,DRM更能适应当前日益更新的显示硬件。 比如FB原生不支持多层合成,不支持VSYNC,不支持DMA-BUF,不支持异步更新,不支持fence机制等等,而这些功能DRM原生都支持。 同时DRM可以统一管理GPU和Display驱动,使得软件架构更为统一…

Clock Switch,芯片时钟切换的毛刺是什么,如何消除

背景 芯片运行过程中需要时钟切换时,要考虑到是否会产生glitch,小小的glitch有可能导致电路运行的错误。所以时钟切换时需要特别的处理。 直接使用MUX进行时钟切换或者采用如下电路结构进行时钟切换:assign outclock = (clk1 & select) | (~select & clk0);或 assig…

【计算机网络】通过ensp实验分析二三层数据包转发过程

一、实验准备 需要提前安装好wireshark、virtalbox、WinPcap和模拟工具ensp,具体的安装过程可以自行百度~ 特别提醒一点就是virtalbox和ensp的兼容性问题,我安装的是ensp1.3.00.100版本,该版本不支持virtalbox官网的6和7版本,我这边退回到5版本才正常运行起来。二、网络拓扑…