js yaml语法编辑器 - CodeMirror使用

js yaml语法编辑器 - CodeMirror使用

下载安装

npm install codemirror --save

  • react 版本下载

npm install react-codemirror2 codemirror --save

支持yaml使用方法

  • 引入样式和语法支持
    在这里插入图片描述
  • 实例化
const yamlCodeMirrorEle = document.getElementById('el');
 this.myCodeMirror = CodeMirror(yamlCodeMirrorEle, {
   value: '',
   mode: 'yaml',
   lineNumbers: true,     // 显示行数
   indentUnit: 1,         // 缩进单位为2
   styleActiveLine: true, // 当前行背景高亮
   matchBrackets: true,   // 括号匹配
   lineWrapping: true,    // 自动换行
   tabSize: 2,
 });
 // 监听输入值变化
 this.myCodeMirror.on('change', (cm) => {
   console.log(eidtorText: cm.doc.getValue())
 })
 // 切换配置方法
 // this.myCodeMirror.setOption('mode', 'javascript')
  • 判断输入值是否为yaml格式
    使用js-yaml库或者yaml库,安装方法npm install js-yaml --save
const parseYamlFn = (str) => {
  let isYaml = false;
  let errorMessage = '';
  try {
    isYaml = !!jsyaml.load(str)
  } catch(e) {
    errorMessage = e && e.message;
  }
  return {
    isYaml, errorMessage
  };
}

效果截图

在这里插入图片描述
感谢您的阅读~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值