在vue3中使用codemirror

文章目录

  • 前言
  • 引入
  • 在vue3中使用
    • 基本配置
    • 更改编辑框的外部样式(高度、宽度)
    • 获取和修改内容
    • 添加删除事件
  • 实现markdown过程中遇到的bug

前言

最近为了完成学校的大作业,需要制作markdown编辑器,为了用户输入方便,使用了codemirror来做编辑器。本文介绍的只是很简单的使用配置,更多内容请查阅官方文档。

引入

npm i codemirror

在vue3中使用

基本配置

具体的配置可以看官方网站
https://codemirror.net/5/doc/manual.html#config

// html部分
<textarea ref="l"></textarea>

// 引入
import CodeMirror from "codemirror";

// codemirror配置
const l = ref(null);
onMounted(() => {
     const editor=CodeMirror.fromTextArea(l.value, {
       mode: "markdown",// 模式
       theme: "solarized", // 主题
       lineWrapping: true,// 自动换行
       scrollPastEnd: true,// 允许用户将一个编辑器高度的空白区域滚动到编辑器底部的视图
       lineNumbers: true,// 显示左边行号(默认false,即不显示)
       styleActiveLine: true, // 当前行背景高亮
     });
}

更改编辑框的外部样式(高度、宽度)

第一种改css

.CodeMirror {
  border: 1px solid #eee;
  height: auto;
}

第二种使用editor.setSize()方法,第一个宽,第二个高

获取和修改内容

// 获取
editor.getValue();
// 修改
editor.setValue('要赋予的值');

添加删除事件

具体可以看官网
https://codemirror.net/5/doc/manual.html#events
以change(当编辑器内容改变时触发,类似于input的change)举例:

editor.on('change', (cm, msg) => {
        console.log(cm == editor);// true
        console.log(msg);// 改变内容的信息
})

第二个参数截图在vue3中使用codemirror_第1张图片

实现markdown过程中遇到的bug

  1. 没有内容也可以滚动,原来的.CodeMirror-sizer的height值为120%(找了有点久/(ㄒoㄒ)/~~
.CodeMirror-sizer {
        height: 100%;
      }
  1. 实现同步滚动过程中遇到鼠标不滚动了,但页面还是滚动的问题,因为两边都绑定了滚动事件,形成了死循环。解决方法:设置一个变量来记录当前哪边触发滚动。
    在vue3中使用codemirror_第2张图片
  2. codemirror报错 Uncaught TypeError: Cannot read properties of undefined (reading ‘map‘)

原因:由于我用了pinia去存储codemirror的对象,获取使用时codemirror对象变成了proxy对象,没有用真正的codemirror对象。
解决方案:在获取使用用toRaw()来获取真正的codemirror对象再使用。

import { toRaw } from "@vue/reactivity";
const editor = toRaw(editorStore().editor);

这样再去使用就不会报错了。
目前为什么这样会出错,我还不知道原因,如果有知道的,请务必告诉我,谢谢!!!

你可能感兴趣的:(javascript,前端,html,vue.js)