iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >codemirror6在线代码编辑器如何使用
  • 259
分享到

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

2023-07-04 23:07:46 259人浏览 泡泡鱼
摘要

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

本篇内容主要讲解“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在线代码编辑器如何使用”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: codemirror6在线代码编辑器如何使用

本文链接: https://www.lsjlt.com/news/348184.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • codemirror6在线代码编辑器如何使用
    本篇内容主要讲解“codemirror6在线代码编辑器如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“codemirror6在线代码编辑器如何使用”吧!介绍  &nbs...
    99+
    2023-07-04
  • codemirror6实现在线代码编辑器使用详解
    目录背景介绍codemirror5、codemirror6对比codemirror6 核心包vue3+codemirror6实现简易在线代码编辑器安装依赖创建编辑器效果截图主题获取、...
    99+
    2023-01-08
    codemirror 代码编辑器 codemirror 在线编辑器
  • java fckeditor在线编辑器的使用
    FCKeditor(现在已经更名为CKEditor)是一个基于JavaScript的HTML文本编辑器,它可以嵌入到网站中,用于在网...
    99+
    2023-08-23
    Java
  • 在线代码编辑器CodeMirror的定位是什么
    在线代码编辑器CodeMirror的定位是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一款“Online Source Editor”,基于Javascr...
    99+
    2023-06-17
  • 【python】Jupyter的使用(python代码编辑器)
    文章目录 一、Jupyter的介绍1、Jupyter是什么?2、Jupyter有什么独特之处? 二、Jupyter的安装1、首先要下载python2、用pip命令下载Jupyter 三...
    99+
    2023-09-01
    python jupyter 编辑器
  • vue codemirror如何实现在线代码编译器
    vue codemirror如何实现在线代码编译器,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。前言如果我们想在Web端实现在线代码编译的效果,那么需...
    99+
    2023-06-22
  • 如何使用vue codemirror插件实现代码编辑器功能
    本篇内容主要讲解“如何使用vue codemirror插件实现代码编辑器功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用vue codemirror插件实现代码编辑器功能”吧!1、使用...
    99+
    2023-07-04
  • TextMate轻量级代码编辑器怎么使用
    使用TextMate轻量级代码编辑器,你需要按照以下步骤操作: 下载和安装TextMate。你可以从TextMate官方网站上下...
    99+
    2023-10-22
    TextMate
  • 如何使用vi编辑器
    本篇内容主要讲解“如何使用vi编辑器”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用vi编辑器”吧!vi有命令模式和插入模式之分。vi启动后就处于命令模式。在命令模式下,可以随意移动光标、...
    99+
    2023-06-10
  • 如何在在Vue3中使用markdown 编辑器组件
    目录安装引入组件基础用法保存后的 markdown 或者 html 文本如何渲染在页面上?安装 # 使用 npm npm i @kangc/v-md-editor@next -S...
    99+
    2024-04-02
  • vue中如何使用codemirror插件实现代码编辑器功能
    这篇文章主要介绍“vue中如何使用codemirror插件实现代码编辑器功能”,在日常操作中,相信很多人在vue中如何使用codemirror插件实现代码编辑器功能问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答...
    99+
    2023-06-20
  • Linux代码编辑器medit怎么用
    这篇文章主要为大家展示了“Linux代码编辑器medit怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Linux代码编辑器medit怎么用”这篇文章吧。medit 是一个面向程序员编程的文...
    99+
    2023-06-27
  • 如何在Linux上使用JOE文本编辑器
    这篇文章将为大家详细讲解有关如何在Linux上使用JOE文本编辑器,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。安装在 Linux 上,你也许能在你的发行版软件仓库中找到 JOE。虽然它有点小众,并不是所...
    99+
    2023-06-15
  • 使用Springboot实现word在线编辑保存
    目录一、查看官网二、查看下载包1、springboot 引入 pageoffice5.2.0.12.jar2、springboot 引入thymleaf3、编写配置文件4、编写 in...
    99+
    2024-04-02
  • 如何使用Mu编辑器Python
    本篇内容主要讲解“如何使用Mu编辑器Python”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用Mu编辑器Python”吧!开始使用 Python 的 turtle 模块在 Linux 或...
    99+
    2023-06-16
  • wps宏编辑器如何使用
    这篇文章主要讲解了“wps宏编辑器如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“wps宏编辑器如何使用”吧!首先打开wps,进入表格,点击上方“开发工具”打开后,点击下面的“js宏”...
    99+
    2023-07-02
  • markdown编辑器tui.editor如何使用
    这篇文章主要介绍“markdown编辑器tui.editor如何使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“markdown编辑器tui.editor如何使用”文章能帮助大家解决问题。安装使用...
    99+
    2023-07-05
  • 如何在文本编辑器中编辑HTML文件
    HTML是一种标记语言,用于创建网页和其他文档。如果你想学习HTML,在你的计算机上需要有一个文本编辑器,这篇文章将介绍如何在文本编辑器中编辑HTML文件,并提供一些提示和技巧。选择文本编辑器首先,你需要选择一个文本编辑器,它应该是可以在你...
    99+
    2023-05-14
  • 如何使用MySQL和JavaScript实现一个简单的在线编辑器功能
    要实现一个简单的在线编辑器功能,可以通过以下步骤使用MySQL和JavaScript来实现:1. 创建一个包含两个字段的MySQL数...
    99+
    2023-10-20
    MySQL
  • Asp.Net Core 使用Monaco Editor 实现代码编辑器功能
    在项目中经常有代码在线编辑的需求,比如修改基于Xml的配置文件,编辑Json格式的测试数据等。我们可以使用微软开源的在线代码编辑器Monaco Editor实现这些功能。Monaco...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作