Molecule , 一个轻量的 Web IDE UI 框架

https://github.com/DTStack/molecule​github.com/DTStack/molecule

简介

Molecule 是一个受 VS Code 启发,使用 React.js 构建的 Web IDE UI 框架。通过一种类似 VS Code 扩展机制(Extension),可快速、轻松搭建一个高度抽象的 Web IDE UI 系统。同时基于 Monaco Editor,内置集成了 QuickAccess 和 Keybinding 等功能,并提供了简单的 API 以供使用。

得益于扩展机制和 React 组件化技术,Molecule 可以针对例如 Workbench UI、 ColorTheme 、自定义热键快捷访问等功能进行自定义扩展。另外,开发者可将业务代码和 IDE UI 架构解耦,在保持业务高速迭代的同时,产品交互体验依然保持良好的可持续进化能力。

自定义 Workbench

动机

数栈(DTInsight) 中例如离线、实时任务开发,算法开发等产品,它们的直接使用人员大部分都是开发者,需要在 Web 上完成代码编写,调试等工作。所以,我们也希望给开发人员创造一个良好的在线 IDE 开发体验。

早期的数栈开发平台

上图中的 RD-OS 是我们数栈开发平台早期的版本,当时产品功能本身比较简单。前端在初期的实现上,基于 React + Ant Design + Codemirror 来搭建的整个 IDE UI 界面。另外,由于当时我们多个产品都有这个 Workbench 的场景,我们还抽象了一个简单且单纯 的 IDE Workbench UI 的 React 组件,以供其他产品复用。

当前的 Web IDE 版本

随着业务发展,产品不断的迭代,整个页面的功能也变得十分密集和复杂。产品布局、视觉、交互等一直在更新和变化,上图已经是我们最新的版本设计。然而,在面对这些新的交互、视觉上的诉求时,早期简单堆叠的技术架构就会显得有些捉襟见肘了。设计师新出的方案,由于改造成本很高,比较难以实施。

大约 2019 年左右,团队和产品交流了市面上做的比较好的 Web IDE 产品,如 Cloud9 IDE、VS Code、Eclipse Theia 等。这些产品都有非常好的 UI 抽象,扩展性很好,定制主题等功能也比较方便。但是这些产品功能比较完整的 IDE,应用到我们产品,就显得有点重,而且对团队技术挑战较大,最重要的是技术迁移成本也比较高,自定义 UI 也不够灵活。

基于这些问题的考虑,团队试图寻找出一种平衡方案。我们希望这个方案有很好的 UI 抽象便于新增功能、UI 可自定义、定制 ColorTheme 简单、React 项目无缝衔接,让产品交互有比较方便的持续进化能力。在对 VS Code 源码研究了一番之后,我们便萌生了 Molecule 这个项目的想法。

核心功能

我们参考了 VS Code 的设计,对 UI 抽象、编辑器、颜色主题等等重新进行了梳理,Molecule 目前的核心功能如下:

  • 内置 React 版本的 Visual Studio Code Workbench UI
  • 基本兼容 Visual Studio Code 的 ColorTheme
  • 支持使用 React 组件自定义 Workbench UI 样式
  • 内置 Monaco Editor Command PaletteKeybinding等模块,并支持扩展
  • 支持 i18n,内置简体中文、English 等两种语言
  • 内置一个简单的 Settings 模块,支持在线编辑修改以及扩展
  • 内置默认的 ExplorerSearch 等组件,并支持扩展
  • Typescript

Workbench 布局

上图是重新抽象的 Workbench UI。基于一个简单的扩展(Extension),如 WorkbenchColorThemeQuickAccessKeybindingi18nSettings 等等功能,通过 Molecule 内置的服务,可以轻松的使用和扩展。

与其他开源的 Web IDE 的区别?

  • React.js 应用无缝接入
  • 基于 React.js 的组件库,更好的 UI 自定义能力
  • 基本兼容了 VS Code 上千种 ColorTheme 扩展
  • Molecule 只是一个单纯的 Web IDEUI 交互框架,不涉及例如文件系统版本管理、 LSP、DAPTerminal 等更复杂的 IDE 功能,需要开发者自己手动实现。

如何使用?

请阅读快速开始文档。

接下来的规划

Molecule 当前还是一个 Beta 版本,很多 API 还不够稳定。早期参考了一些 VS Code 的设计概念,API 设计不够简单;目前默认的 Workbench 是 VS Code 版本的布局,后期会考虑丰富布局(Layout)系统;Color Theme 交互还有很多细节需要优化。

我们开源了一个轻量的 Web IDE UI 框架 - Molecule相关推荐

  1. Javalin:一个轻量的 Web Framework

    说起 Java 语言下的 Web 框架那就非 Spring Framework 不可了,但是今天在和别人在聊天的过程中发现了一个新奇的项目 Javalin.Javalin 是一个轻量的 Web 框架. ...

  2. Raspkate - 基于.NET的可运行于树莓派的轻量型Web服务器

    最近在业余时间玩玩树莓派,刚开始的时候在树莓派里写一些基于wiringPi库的C语言程序来控制树莓派的GPIO引脚,从而控制LED发光二极管的闪烁,后来觉得,是不是可以使用HTML5+jQuery等流 ...

  3. 基于轻量型Web服务器Raspkate的RESTful API的实现

    在上一篇文章<Raspkate - 基于.NET的可运行于树莓派的轻量型Web服务器>中,我们已经了解了Raspkate这一轻量型Web服务器,今天,我们再一起了解下如何基于Raspkat ...

  4. 【原创】开源OpenIM:轻量、高效、实时、可靠、低成本的消息模型

    [原创]开源OpenIM:轻量.高效.实时.可靠.低成本的消息模型 1.内容概述 一套完整IM系统中,除开基本的业务设计,消息模型的设计是其中最为关键的一环,它关系到整个IM系统的可靠性.高效性.稳定 ...

  5. Multipass - 一个轻量虚拟机管理器

    Multipass 是一个轻量虚拟机管理器,是由 Ubuntu 运营公司 Canonical 所推出的开源项目.运行环境支持 Linux.Windows.macOS.在不同的操作系统上,使用的是不同的 ...

  6. 在 C++ 中实现一个轻量的标记清除 gc 系统

    在 C++ 中实现一个轻量的标记清除 gc 系统 最近想把 engine 做一个简单 C++ 封装,结合 QT 使用.engine 本身是用纯 C 实现的,大部分应用基于 lua 开发.对对象生命期管 ...

  7. 关于VSCode中工作区的讲解与使用工作区还你一个轻量 的VSCode

    VSCode的使用率在逐渐提高,但安装太多的插件会使得VSCode变得臃肿,甚至运行变慢,占用太多内存,此文章介绍了工作区,并如何来使用工作区更好地体验VSCode. 初次使用VSCode,肯定有很多 ...

  8. windows中常用的一个轻量的扫描软件xray_windows_amd64

    1.xray_windows_amd64现在windows中常用的一个轻量的扫描软件,用法要求各位同学通过物联网查找使用方式 完成对文章管理系统cms页面进行漏洞扫描. ①安装证书,在命令框xray_ ...

  9. 2014年最受欢迎WEB前端UI框架

    2014年已经过了一半,WEB前端受到更多人的观注,WEB前端也已经逐渐成为一种职业头衔! 相应的WEB前端UI框架更是受到新人追捧,下边为大家列出目前最受欢迎.最优秀的前端框架以供大家选择一款适合自 ...

最新文章

  1. re模块与正则表达式
  2. 可想实现一个自己的简单jQuery库?(五)
  3. 解决windows显示开启HDR后chrome内截图泛白问题
  4. 台湾国立大学郭彦甫Matlab教程笔记(12) advanced 2D plot 下
  5. OpenCASCADE:函数机制的使用
  6. ❤️《大前端—Babel》
  7. Python库安装注意事项
  8. Android 文件管理器 Android文件管理器源代码
  9. python九九乘法表矩形_用Python实现九九乘法表
  10. 残缺、时间一起的爱情
  11. 【DIY分享】示波器(原理图+源码+仿真)
  12. GCC 优化选项 -O -O0 -O1 -O2 -O3 -Os 简单介绍
  13. Arduino 调用Stepper库驱动28BYJ-48步进电机,电机振动不转、无法反方向转的解决办法
  14. Windows11无法打开Windows安全中心(需要使用新应用打开此windowsdefender链接)
  15. 操作系统实验八:页面置换模拟程序设计
  16. android usb wifi驱动下载,android 平台USB wifi驱动移植及使用
  17. Linux 磁盘管理 : mount 命令详解
  18. 个人网站音乐服务器,不在是想象:教你搭建个人音乐播放网站(3)
  19. Jlink新版驱动安装目录无JLinkDevices.xml添加新器件方法
  20. 【情感识别】基于ELM、SOM分类器实现心率变异性信号情感识别附matlab代码

热门文章

  1. 利用 JS 脚本实现网页全自动秒杀抢购
  2. python3多线程爬虫小说_python3+beautifulSoup4.6抓取某网站小说(四)多线程抓取
  3. 星空电影院 v6.08 bt
  4. 饥荒机器人升级上限多少_升级之后的机器人,饥荒世界不可忽视的恐怖存在
  5. 初中生计算机课程教案,初中信息技术上机课题【初中信息技术课上机实验教学】...
  6. 6份2021 VDC:vivo 开发者大会(PPT汇总)
  7. IDEA 使用VUE框架
  8. 正则表达式中小括号()的作用是什么
  9. 什么是软件开发?(^_^)
  10. Sublime Text 3143 Win32版本暴力破解过程