monaco-editor

访客4年前黑客文章1187

Momonaco-editor是微软提供的代码编辑器,vscode即是使用它作为编辑器。它的开发语言是ts,可以嵌入到浏览器中。


安装

npm install monaco-editor复制代码

引用

本人写Vue + Webpack 较多,以此为例:

之一种写法: 使用  monaco-editor-webpack-plugin

// .vue 对应的 script剧本中
import * as monaco from 'monaco-editor';

monaco.editor.create(document.getElementById('container'), {
  value: [
    'function x() {',
    '\tconsole.log("Hello world!");',
    '}'
  ].join('\n'),
  language: 'javascript'
});
// 在 webpack.base.conf.js 中
// 需要安装 monaco-editor-webpack-plugin

const MonacoWebpackPlugin = require('monaco-editor-webpack-plugin');
const path = require('path');
module.exports = {
  ...
  plugins: [
    new MonacoWebpackPlugin()
  ]
};

第二种写法:

// .vue 对应的 script剧本中

import * as monaco from 'monaco-editor';

// Since packaging is done by you, you need
// to instruct the editor how you named the
// bundles that contain the web workers.
self.MonacoEnvironment = {
  getWorkerUrl: function (moduleId, label) {
    if (label === 'json') {
      return './json.worker.bundle.js';
    }
    if (label === 'css') {
      return './css.worker.bundle.js';
    }
    if (label === 'html') {
      return './html.worker.bundle.js';
    }
    if (label === 'typescript' || label === 'javascript') {
      return './ts.worker.bundle.js';
    }
    return './editor.worker.bundle.js';
  }
}

monaco.editor.create(document.getElementById('container'), {
  value: [
    'function x() {',
    '\tconsole.log("Hello world!");',
    '}'
  ].join('\n'),
  language: 'javascript'
});
// 在 webpack.base.conf.js 中
// 不需要安装任何剧本const path = require('path');

module.exports = {
  entry: {
    "app": './index.js',
    // Package each language's worker and give these filenames in `getWorkerUrl`
    "editor.worker": 'monaco-editor/e *** /vs/editor/editor.worker.js',
    "json.worker": 'monaco-editor/e *** /vs/language/json/json.worker',
    "css.worker": 'monaco-editor/e *** /vs/language/css/css.worker',
    "html.worker": 'monaco-editor/e *** /vs/language/html/html.worker',
    "ts.worker": 'monaco-editor/e *** /vs/language/typescript/ts.worker',
  },
  ...
};
返回列表

上一篇:RemoveBG

下一篇:progress.js

相关文章

系统资讯有哪些(windows7正版系统怎么升级)

系统资讯有哪些(windows7正版系统怎么升级)

烦人的弹窗广告 最初笔者就是忍受不了Windows一开机弹窗就铺天盖地,所以才转战国产操作系统。本来电脑配置不高,加上弹窗一堆,开机反应慢的很。而中兴新支点操作系统对于配置的要求不高,日常使用都...

脸上的红血丝怎么治(民间偏方去除红血丝的)

  有红血丝关键是由于脸部毛细管扩大或一部分毛细管部位浅表造成的脸部状况。有红血丝最非常容易发生在脸颊,鼻部周边,在白皙的皮肤上特别是在显著。一到秋天,敏感性皮肤由于承担不上迟早温度差及其干燥等众多难...

微信疯狂猜字黑客的简单介绍

微信疯狂猜字黑客的简单介绍

本文目录一览: 1、微信疯狂猜猜第136关怎么过 2、微信疯狂猜猜神第604关成语答案 3、微信小程序 疯狂猜猜 全部答案? 4、微信上的疯狂猜成语是不是骗人的 5、微信小程序疯狂猜猜...

牛炖牛板筋火锅区域代理费用是多少?一起来看看!

牛炖牛板筋火锅区域代理费用是多少?一起来看看!

牛炖牛板筋暖锅加盟项目在市场上的成长是我们各人有目共睹的,这个加盟项目很是适合我们这些没什么资金,可是想要开店创业的人去加盟!牛炖牛板筋暖锅加盟项目在市场上,创立多年,品牌形象早就已经深入到人心了,深...

北京市密云区政协原党瑞凰组书记、主席王稳东被双

  北京市密云区政协原党组书记、主席王稳东被开除党籍和公职   中央纪委国家监委网站讯 据北京市纪委监委消息:日前,经北京市委批准,北京市纪委市监委对北京市密云区政协原党组书记、主席王稳东严重违纪违...