vue3中使用codemirror的详细教程

 更新时间:2023年09月06日 09:08:12   作者:清缓存试试  
这篇文章主要给大家介绍了关于vue3中使用codemirror的详细教程,CodeMirror是一款功能强大的代码高亮插件,他不仅提供了高亮功能,其丰富的方法属性也封装了缩进、自动换行、获取编辑文本、设置编辑文本、回退功能等多种实用效果,需要的朋友可以参考下

前言

最近为了完成学校的大作业,需要制作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);// 改变内容的信息
})

第二个参数截图

实现markdown过程中遇到的bug

没有内容也可以滚动,原来的.CodeMirror-sizer的height值为120%(找了有点久/(ㄒoㄒ)/~~

.CodeMirror-sizer {
        height: 100%;
      }

实现同步滚动过程中遇到鼠标不滚动了,但页面还是滚动的问题,因为两边都绑定了滚动事件,形成了死循环。解决方法:设置一个变量来记录当前哪边触发滚动。

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);

这样再去使用就不会报错了。目前为什么这样会出错,我还不知道原因!!!

总结

到此这篇关于vue3中使用codemirror的文章就介绍到这了,更多相关vue3使用codemirror内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 解决vue中el-date-picker type=daterange日期不回显的问题

    解决vue中el-date-picker type=daterange日期不回显的问题

    这篇文章主要介绍了解决vue中el-date-picker type=daterange日期不回显的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • VUE实现一个Flappy Bird游戏的示例代码

    VUE实现一个Flappy Bird游戏的示例代码

    这篇文章主要介绍了VUE实现一个Flappy Bird的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • vue去除数组指定位置元素的几种方法

    vue去除数组指定位置元素的几种方法

    这篇文章主要介绍了vue剔除数组指定位置元素的几种方法,文中主要介绍了单个去除和批量去除这两种方法,并通过代码示例讲解的非常详细,需要的朋友可以参考下
    2024-03-03
  • vue同一个浏览器登录不同账号数据覆盖问题解决方案

    vue同一个浏览器登录不同账号数据覆盖问题解决方案

    同一个浏览器登录不同账号session一致,这就导致后面登录的用户数据会把前面登录的用户数据覆盖掉,这个问题很常见,当前我这边解决的就是同一个浏览器不同窗口只能登录一个用户,对vue同一个浏览器登录不同账号数据覆盖问题解决方法感兴趣的朋友一起看看吧
    2024-01-01
  • vue中子组件的methods中获取到props中的值方法

    vue中子组件的methods中获取到props中的值方法

    今天小编就为大家分享一篇vue中子组件的methods中获取到props中的值方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-08-08
  • react和vue的事件处理差异详解

    react和vue的事件处理差异详解

    这篇文章主要介绍了react和vue的事件处理差异,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03
  • VUE中操作dom元素的几种方法(最新推荐)

    VUE中操作dom元素的几种方法(最新推荐)

    本文给大家总结了Vue中操作dom元素的多种方法,每种方法结合实例代码给大家讲解的非常详细,需要的朋友参考下吧
    2022-12-12
  • axios请求头设置常见Content-Type和对应参数的处理方式

    axios请求头设置常见Content-Type和对应参数的处理方式

    这篇文章主要介绍了axios请求头设置常见Content-Type和对应参数的处理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03
  • 使用vue实现grid-layout功能实例代码

    使用vue实现grid-layout功能实例代码

    这篇文章主要介绍了使用vue实现grid-layout功能的代码讲解,需要的朋友可以参考下
    2018-01-01
  • Vue项目请求超时处理方式

    Vue项目请求超时处理方式

    这篇文章主要介绍了Vue项目请求超时处理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12

最新评论