在vue3中使用codemirror
作者:小教学发布时间:2023-10-01分类:程序开发学习浏览:88
导读:文章目录前言引入在vue3中使用基本配置更改编辑框的外部样式(高度、宽度)获取和修改内容添加删除事件实现markdown过程中遇到的bug前言最近为了完成学...
文章目录
- 前言
- 引入
- 在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);// 改变内容的信息
})
第二个参数截图
实现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);
这样再去使用就不会报错了。
目前为什么这样会出错,我还不知道原因,如果有知道的,请务必告诉我,谢谢!!!
- 上一篇:Java Web 开发详解
- 下一篇:SpringCloud网关服务
- 程序开发学习排行
-
- 1鸿蒙HarmonyOS:Web组件网页白屏检测
- 2HTTPS协议是安全传输,为啥还要再加密?
- 3HarmonyOS鸿蒙应用开发——数据持久化Preferences
- 4记解决MaterialButton背景颜色与设置值不同
- 5鸿蒙HarmonyOS实战-ArkUI组件(RelativeContainer)
- 6鸿蒙HarmonyOS实战-ArkUI组件(Stack)
- 7鸿蒙HarmonyOS实战-ArkUI组件(GridRow/GridCol)
- 8[Android][NDK][Cmake]一文搞懂Android项目中的Cmake
- 9鸿蒙HarmonyOS实战-ArkUI组件(mediaquery)
- 最近发表
-
- WooCommerce最好的WordPress常用插件下载博客插件模块的相关产品
- 羊驼机器人最好的WordPress常用插件下载博客插件模块
- IP信息记录器最好的WordPress常用插件下载博客插件模块
- Linkly for WooCommerce最好的WordPress常用插件下载博客插件模块
- 元素聚合器Forms最好的WordPress常用插件下载博客插件模块
- Promaker Chat 最好的WordPress通用插件下载 博客插件模块
- 自动更新发布日期最好的WordPress常用插件下载博客插件模块
- WordPress官方最好的获取回复WordPress常用插件下载博客插件模块
- Img to rss最好的wordpress常用插件下载博客插件模块
- WPMozo为Elementor最好的WordPress常用插件下载博客插件模块添加精简版