跑在浏览器上的小程序 IDE

简介: 本文向大家介绍我们怎样借助开天 IDE 框架把小程序开发者工具跑在浏览器中,小程序 WebIDE 背后都做了些什么。

作者 | 北木

image.png

在过去的一年里,支付宝小程序 IDE 团队作为共建的一份子加入到了开天 IDE 框架的开发中,随着开天框架逐渐成熟,去年年底我们把小程序开发者工具全面升级到了开天内核。在小程序开发者工具与开天 IDE 框架完成融合后,我们尝试把小程序开发者工具搬到了浏览器中...

本文向大家介绍我们怎样借助开天 IDE 框架把小程序开发者工具跑在浏览器中,小程序 WebIDE 背后都做了些什么。

场景梳理

image.pngMiniCode IDE



在小程序开发者工具中我们支持了非常丰富且复杂的小程序研发能力,在把它们搬上浏览器之前,我们首先对 WebIDE 的方向做了些思考:
  • 希望开发者能够在 WebIDE 中完成「研发并上线一个小程序」的全部流程,但不希望 WebIDE 变得和客户端一样庞大
  • 希望 WebIDE 能够和客户端形成能力互补,完成一些客户端难以完成的场景(比如分享与传播)
  • 希望 WebIDE 和客户端在底层技术上是互通的,不要产生技术上的分化

基于这些思考,我们从小程序开发者工具中抽取出了一条主要的研发链路,在 WebIDE 中实现:创建/管理项目 -> 编辑代码 -> 模拟器预览与调试 -> 真机调试 -> 真机预览 -> 上传提审。

整体架构

image.png

整体上主要分成了两部分:

  • 应用服务器 MiniAppWeb,它负责管理用户和 IDE 实例之间的关系以及 IDE 的生命周期,这部分细节不赘述
  • IDE 容器 MiniCode,它是基于开天框架 IDE 的本体,部署在阿里云 k8s 集群中,我们主要介绍这部分

启动流程

在介绍细节前,我们先来看一下一次完整的 IDE 启动流程(简化版):

image.png

在整个启动流程中,耗时最严重的是「创建 MiniCode 容器」这一步,冷启动耗时大约在 10 秒左右。为了优化这一启动时间,我们将用户状态的载入后置到「MiniCode 加载工作空间代码」这一步,同时在集群中预热一批无状态的 MiniCode 容器,把「创建 MiniCode 容器并启动」转换为了「从预热池中选择闲置的 MiniCode 容器」,极大幅度降低了启动耗时。

目前一次全新的 IDE 启动在命中预热容器的情况下仅耗时 3 秒左右。

IDE Server & Exexutable

IDE Server 以 Koa 为载体运行了开天 IDE 框架,在开天框架中,我们扩展了 MiniProgram 模块、Project 模块等用于对小程序研发场景进行 UI 适配、流程组装、提供相应的项目管理能力等。MiniCode IDE 中的 Toolbar、项目信息等由这些模块完成。

Executable 是由 MiniCode 容器提供的一系列管理脚本,供 MiniAppWeb 通过远程调用的方式执行,用于运行过程中从外部介入容器进行操作。「启动流程」中介绍的「加载工作空间代码」、「启动 MiniCode IDE 服务」均由这些脚本提供。

MiniCode 插件

真正的小程序研发能力被分解成了一些独立的开天 IDE 插件:

  • minicode-basis:提供小程序基础服务
  • minicode-compile:提供小程序编译相关服务,包括 DevServer、真机调试、真机预览构建等
  • minicode-simulator:提供小程序模拟器相关服务
  • minicode-devtool:提供小程序调试器相关服务

它们分别以 command 的形式提供了独立的接口供外部调用,比如:

import { commands } from 'kaitian';

// 启动小程序构建 DevServer
commands.executeCommand('mini-program.compile.startDevServer');

// 启动并打开模拟器
commands.executeCommand('mini-program.simulator.open');

// 打开真机调试
commands.executeCommand('mini-program.devtools.openRemoteDebug');

compile/simulator/devtool 相互之间独立且仅和 basis 耦合,它们既可以作为一个 Extension Pack 整体来提供全部的小程序研发能力,又可以分别启用以提供特定的功能。

MiniCode 插件的分层设计以及以 command 形式提供接口的方式为它带来了对开天 IDE 框架优秀的兼容能力,任何使用开天 IDE 框架构建的 IDE 产品均可通过集成 MiniCode 插件的方式方便地接入小程序研发,比如蚂蚁内部 Cloud IDE 近期通过这种方式接入了小程序技术栈:

image.png

业务落地

技术上完成了预设的场景后,我们开始尝试把小程序 WebIDE 在一些业务场景落地,比如:

增加便捷入口

image.png

在小程序文档、开放平台等多处部署了不同的入口,让小程序开发的开发者可以随时点开 WebIDE 体验小程序开发、修改自己的代码。

分享项目

image.png

一键给自己的项目创建分享链接,快速分享自己的代码给他人。

未来

小程序 WebIDE 还在起步阶段,目前仅仅做到了完成小程序研发生命周期的全流程,但并不够好用。

比如,出于阿里云集群容量考虑,小程序 WebIDE 现在要求用户登录之后才能使用,这在一定程度上让「项目分享」这样的功能变得鸡肋了些:我们总不能指望点开分享链接的人会去登录一次吧。

未来我们会继续探索 Web 上轻量化研发的场景:通过一个比 WebIDE 更加轻量的小程序 Playground,让小程序分享变得更加简单;通过 Playground、WebIDE、客户端 IDE 等产品的联动,让开发小程序更加高效和有趣。

最后,感谢阅读,欢迎体验小程序 WebIDE:https://minicode.alipay.com/


image.png
关注「Alibaba F2E」
把握阿里巴巴前端新动向

相关文章
|
8月前
|
移动开发 小程序 API
微信外部浏览器或短信链接唤起微信小程序的解决方案
微信外部浏览器或短信链接唤起微信小程序的解决方案
1666 1
|
8月前
|
Web App开发 小程序 前端开发
【产品上新】小程序新内核来了!提升安卓浏览器性能,支持WebRTC
【产品上新】小程序新内核来了!提升安卓浏览器性能,支持WebRTC
142 10
|
8月前
|
移动开发 小程序 IDE
【社区每周】小程序搜索直达能力全面开放;IDE3.0稳定版正式发布(2022年6月第二期)
【社区每周】小程序搜索直达能力全面开放;IDE3.0稳定版正式发布(2022年6月第二期)
63 0
|
6月前
|
移动开发 小程序 前端开发
php + h5使用 scheme页面跳转微信小程序-其他浏览器一键跳转到微信并打开小程序
php + h5使用 scheme页面跳转微信小程序-其他浏览器一键跳转到微信并打开小程序
143 0
|
8月前
|
小程序 IDE Go
社区每周丨小程序企业经营类目升级及IDE新版本上线(4月第1周)
社区每周丨小程序企业经营类目升级及IDE新版本上线(4月第1周)
66 0
|
Web App开发 前端开发 JavaScript
JavaScript浏览器开发者工具和常用的IDE的调试功能
JavaScript浏览器开发者工具和常用的IDE的调试功能
|
Web App开发 小程序 安全
微信小程序首次请求慢 Safari浏览器访问慢 pending 10秒 可能是HTTPS证书的锅
微信小程序首次请求慢 Safari浏览器访问慢 pending 10秒 可能是HTTPS证书的锅
454 0
微信小程序首次请求慢 Safari浏览器访问慢 pending 10秒 可能是HTTPS证书的锅
|
IDE 编译器 程序员
CSDN推出【云IDE】,几秒完成开发环境配置,今后可以在浏览器里使用VS Code了
CSDN推出【云IDE】,几秒完成开发环境配置,今后可以在浏览器里使用VS Code了
220 0
CSDN推出【云IDE】,几秒完成开发环境配置,今后可以在浏览器里使用VS Code了
|
小程序 前端开发 Linux
奇思妙想:小程序wxapkg包一键运行至浏览器?
本文探讨的是如何将 wxapkg 小程序代码包运行至浏览器
594 0
|
2月前
|
JSON 移动开发 JavaScript
在浏览器执行js脚本的两种方式
【10月更文挑战第20天】本文介绍了在浏览器中执行HTTP请求的两种方式:`fetch`和`XMLHttpRequest`。`fetch`支持GET和POST请求,返回Promise对象,可以方便地处理异步操作。`XMLHttpRequest`则通过回调函数处理请求结果,适用于需要兼容旧浏览器的场景。文中还提供了具体的代码示例。
在浏览器执行js脚本的两种方式