我的编程空间,编程开发者的网络收藏夹
学习永远不晚

codemirror6在线代码编辑器如何使用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

codemirror6在线代码编辑器如何使用

本篇内容主要讲解“codemirror6在线代码编辑器如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“codemirror6在线代码编辑器如何使用”吧!

介绍

    CodeMirror是Web的代码编辑器组件。它可以在网站中用于实现文本输入字段,并支持许多编辑功能,并具有丰富的编程接口以允许进一步扩展。

codemirror5、codemirror6对比

    其实codemirror官网中的迁移指南有详细列举两个版本关键特性的一些对比,下面列举一些实际项目中用到的特性对比:

对比项codemirror5codemirror6
创建编辑器codemirror.fromTextarea(element)import { basicSetup, EditorState, EditorView } from '@codemirror/basic-setup';
const editor = new EditorView({state:EditorState.create(
{doc: code,extensions: [basicSetup]}),
parent: this.$refs.editor as HTMLDivElement,});
设置值cm.setValue(text)①更改值:cm.dispatch({changes: {from: 0, to:cm.state.doc.length, insert: text}})
②替换整个状态:cm.setState(EditorState.create({doc: text, extensions: ...}))
取值cm.getValue()cm.state.doc.toString()

codemirror6 核心包

    由上表的对比也可以看出,codemirror6创建编辑器需要靠自己组装,组装部分并不难,但必须安装并导入所需的组件。以下是核心包,没有它们就很难设置一个编辑器,它们是:

  • @codemirror/state,它定义了表示编辑器状态和对该状态的更改的数据结构。

  • @codemirror/view,这是一个显示组件,它知道如何向用户显示编辑器状态,并将基本的编辑操作转换为状态更新。

  • @codemirror/commands定义了很多编辑命令和一些键绑定。

    举个栗子,我们可以看官网对于最轻量的编辑器的示例:

import {EditorState} from "@codemirror/state"import {EditorView, keymap} from "@codemirror/view"import {defaultKeymap} from "@codemirror/commands"let startState = EditorState.create({  // 显示文本  doc: "Hello World",  // 扩展,**keymap:** 配置要使用的快捷键;语言包等也是作为扩展在此配置  extensions: [keymap.of(defaultKeymap)]})let view = new EditorView({  // 状态  state: startState,  // 绑定元素  parent: document.body})

vue3+codemirror6实现简易在线代码编辑器

安装依赖

// 安装codemirrornpm i codemirror// 这里语言包要自行安装npm i  @codemirror/lang-javascript

创建编辑器

<template>  <div ref="editorRef" class="editor-main"></div></template><script lang="ts" setup>import { basicSetup, EditorView } from "codemirror";import { EditorState } from "@codemirror/state";import { javascript } from "@codemirror/lang-javascript";import {json} from '@codemirror/lang-json'import { onMounted, ref } from "vue";const editorRef = ref();const editorView = ref();const initEditor = () => {  if (typeof editorView.value !== "undefined") {    editorView.value.destroy();  }  const jsonString = `{  root: true,  extends: [    "plugin:vue/vue3-essential",    "eslint:recommended",    "@vue/eslint-config-typescript",    "@vue/eslint-config-prettier",    "vue-global-api"  ],  parserOptions: {    ecmaVersion: "latest",  },  rules: {    "no-console": process.env.NODE_ENV === "production" ? "warn" : "off",    "no-debugger": process.env.NODE_ENV === "production" ? "warn" : "off",    endOfLine: "auto",    "prettier/prettier": ["error", { "endOfLine": "auto" }]  },}`  const startState = EditorState.create({    doc:jsonString,    extensions: [basicSetup, javascript(),json()],  });  if (editorRef.value) {    editorView.value = new EditorView({      state: startState,      parent: editorRef.value,    });  }};// onMounted生命周期可以保证读取到dom元素onMounted(() => {  initEditor();});</script><style lang="scss" scoped>.editor-main{  width: 100vw;  height: 100vh;}</style>

    这里的basicSetup扩展包含了行号,不需要再做额外的配置~

效果截图

codemirror6在线代码编辑器如何使用

主题

    codemirror6目前提供了theme-one-dark主题,也可以使用theme进行拓展

// 安装npm i @codemirror/theme-one-dark// 使用import { oneDarkTheme } from "@codemirror/theme-one-dark";const startState = EditorState.create({    doc: jsonString,    extensions: [basicSetup,oneDarkTheme, javascript(), json()],  });// 自定义主题const  myTheme = EditorView.theme({  "&": {    color: "white",    backgroundColor: "#034"  },  ".cm-content": {    caretColor: "#0e9"  },  "&.cm-focused .cm-cursor": {    borderLeftColor: "#0e9"  },  "&.cm-focused .cm-selectionBackground, ::selection": {    backgroundColor: "#074"  },  ".cm-gutters": {    backgroundColor: "#045",    color: "#ddd",    border: "none"  }}, {dark: true})// 使用  const startState = EditorState.create({    doc: jsonString,    extensions: [basicSetup,myTheme, javascript(), json()],  });

主题效果截图:

codemirror6在线代码编辑器如何使用

获取、更改编辑器的值

    从两个版本对比中也可以知道,codemirror6值的操作主要是对state的操作,数据流的互动如下图所示,即该视图聆听事件。当DOM事件进来时,它(或绑定到密钥的命令或按扩展名注册的事件处理程序)将其转换为状态交易并分配它们。这建立了一个新状态。当将新状态授予视图时,它将自行更新。

codemirror6在线代码编辑器如何使用

const undateValue = ()=>{  const value = editorView.value.state.doc.toString()  if(value){   // 具体逻辑根据自己业务场景做变化    editorView.value.dispatch({changes: {from: 0, to:editorView.value.state.doc.length, insert: 'test'}})  }}

到此,相信大家对“codemirror6在线代码编辑器如何使用”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

codemirror6在线代码编辑器如何使用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

codemirror6在线代码编辑器如何使用

本篇内容主要讲解“codemirror6在线代码编辑器如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“codemirror6在线代码编辑器如何使用”吧!介绍 CodeMirror是W
2023-07-04

codemirror6实现在线代码编辑器使用详解

这篇文章主要为大家介绍了codemirror6实现在线代码编辑器使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-01-08

java fckeditor在线编辑器的使用

FCKeditor(现在已经更名为CKEditor)是一个基于JavaScript的HTML文本编辑器,它可以嵌入到网站中,用于在网页中创建和编辑内容。以下是使用Java集成FCKeditor的步骤:1. 首先,将CKEditor的Java
2023-08-23

在线代码编辑器CodeMirror的定位是什么

在线代码编辑器CodeMirror的定位是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一款“Online Source Editor”,基于Javascr
2023-06-17

vue codemirror如何实现在线代码编译器

vue codemirror如何实现在线代码编译器,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。前言如果我们想在Web端实现在线代码编译的效果,那么需要使用组件
2023-06-22

如何使用vue codemirror插件实现代码编辑器功能

本篇内容主要讲解“如何使用vue codemirror插件实现代码编辑器功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用vue codemirror插件实现代码编辑器功能”吧!1、使用
2023-07-04

如何使用vi编辑器

本篇内容主要讲解“如何使用vi编辑器”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用vi编辑器”吧!vi有命令模式和插入模式之分。vi启动后就处于命令模式。在命令模式下,可以随意移动光标、
2023-06-10

vue中如何使用codemirror插件实现代码编辑器功能

这篇文章主要介绍“vue中如何使用codemirror插件实现代码编辑器功能”,在日常操作中,相信很多人在vue中如何使用codemirror插件实现代码编辑器功能问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答
2023-06-20

TextMate轻量级代码编辑器怎么使用

使用TextMate轻量级代码编辑器,你需要按照以下步骤操作:下载和安装TextMate。你可以从TextMate官方网站上下载适合你操作系统的版本,并按照安装程序的指示进行安装。打开TextMate。一旦安装完成,你可以在应用程序文件夹中
2023-10-22

如何在Linux上使用JOE文本编辑器

这篇文章将为大家详细讲解有关如何在Linux上使用JOE文本编辑器,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。安装在 Linux 上,你也许能在你的发行版软件仓库中找到 JOE。虽然它有点小众,并不是所
2023-06-15

markdown编辑器tui.editor如何使用

这篇文章主要介绍“markdown编辑器tui.editor如何使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“markdown编辑器tui.editor如何使用”文章能帮助大家解决问题。安装使用
2023-07-05

wps宏编辑器如何使用

这篇文章主要讲解了“wps宏编辑器如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“wps宏编辑器如何使用”吧!1、首先打开wps,进入表格,点击上方“开发工具”2、打开后,点击下面的“
2023-07-02

如何使用Mu编辑器Python

本篇内容主要讲解“如何使用Mu编辑器Python”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用Mu编辑器Python”吧!开始使用 Python 的 turtle 模块在 Linux 或
2023-06-16

如何使用MySQL和JavaScript实现一个简单的在线编辑器功能

如何使用MySQL和JavaScript构建在线编辑器本教程将指导您使用MySQL和JavaScript构建一个简单的在线编辑器,允许用户在线创建、编辑和保存文本。我们介绍了构建数据库、建立连接、获取文本、创建、编辑和保存文本的步骤。还提供了示例代码,展示了如何使用JavaScript与MySQL数据库交互。为了优化性能,我们讨论了分块读取、缓存和事务等技术。
如何使用MySQL和JavaScript实现一个简单的在线编辑器功能
2024-04-11

如何使用MySQL和JavaScript实现一个简单的在线编辑器功能

要实现一个简单的在线编辑器功能,可以通过以下步骤使用MySQL和JavaScript来实现:1. 创建一个包含两个字段的MySQL数据库表,一个用于存储文件名,一个用于存储文件内容。可以使用以下命令创建表:CREATE TABLE file
2023-10-20

CentOS中如何使用vi编辑器

这期内容当中小编将会给大家带来有关CentOS中如何使用vi编辑器,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1、vi的基本概念 基本上vi可以分为三种状态,分别是命令模式(command mode)、
2023-06-10

先进SlickEdit编辑器如何使用

这期内容当中小编将会给大家带来有关先进SlickEdit编辑器如何使用,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。SlickEdit 作为一个高效的.NET程序语言。其混合了函数语言和物件导向程序编制语
2023-06-17

vue中wangEditor5编辑器如何使用

这篇文章主要介绍了vue中wangEditor5编辑器如何使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue中wangEditor5编辑器如何使用文章都会有所收获,下面我们一起来看看吧。一、wangEdi
2023-07-05

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录