Heim >Web-Frontend >js-Tutorial >WebContainer 1.0 ist erschienen! Lassen Sie uns darüber sprechen, was WebContainer sind!

WebContainer 1.0 ist erschienen! Lassen Sie uns darüber sprechen, was WebContainer sind!

藏色散人
藏色散人nach vorne
2023-02-23 15:44:033762Durchsuche

Vorwort

Im Jahr 2021 veröffentlichte StackBlitz WebContainers, ein neues Betriebssystem auf Basis von WebAssembly, das es Node.js ermöglicht, vollständig im Browser zu laufen. In den letzten zwei Jahren haben jeden Monat Millionen von Entwicklern WebContainer verwendet, beispielsweise der Editor der typischen Anwendung StackBlitz.

14. Februar 2023 StackBlitz hat die WebContainer-API öffentlich veröffentlicht und lädt die gesamte JavaScript- und Node.js-Community ein, Anwendungen auf WebContainern zu erstellen! Zum Zeitpunkt der Veröffentlichung dieses Artikels hat StackBlitz öffentliche Produkte wie StackBlitz Editor, Codeflow IDE und Web Publisher basierend auf WebContainer entwickelt.

1. Was sind WebContainer?

WebContainers ist ein kleines Betriebssystem, das auf WebAssembly basiert und das lokale Starten von Node.js-Servern in einem Browser-Tab ermöglicht. Betrachten Sie es als eine „Elektronen-Polyfüllung“, die nahtlos bereitgestellt wird, wenn die Seite im Browser geladen wird.

WebContainer 1.0 ist erschienen! Lassen Sie uns darüber sprechen, was WebContainer sind!

WebContainer bieten eine API, die einen Headless-Zugriff ermöglicht und Entwicklern die Flexibilität gibt, ihre eigenen Anwendungen auf der Grundlage der Technologie zu erstellen. Gleichzeitig wurden viele Funktionen von WebContainern als Open Source bereitgestellt und für Unternehmensanwendungsfälle unterstützt und lizenziert. Zu den Hauptfunktionen von WebContainern gehören:

WebContainer 1.0 ist erschienen! Lassen Sie uns darüber sprechen, was WebContainer sind!
  • Führen Sie einen nativen Paketmanager aus : Führen Sie native Versionen von npm, pnpm und Yarn in Ihrem Browser aus, alles innerhalb Ihrer Anwendung, bis zu zehnmal schneller als native Zeiten.
  • Vollständige Browserunterstützung: Unterstützung Führen Sie WebContainer in allen gängigen Browsern aus, von Chromium-basierten Browsern bis hin zu Firefox oder Safari TP
  • Alle wichtigen Framework-Unterstützung:Starten Sie sofort mit der Ausführung auf jeder gängigen modernen A-Einwegumgebung für der Rahmen.
  • Wasm sofort ausführen: Portieren Sie Ihre Lieblingssprache oder Ihr bevorzugtes Framework zur Ausführung in WebContainers

2. Hauptfunktionen der WebContainers-API

2.1 In-Browser-Dateisystem

WebContainers werden über ein temporäres virtuelles Dateisystem gestartet, das im Speicher gespeichert ist und es Entwicklern ermöglicht, Dateien und Verzeichnisse programmgesteuert zu laden/zu laden und Standard-Dateisystemoperationen an ihnen auszuführen.

const file = await webcontainerInstance.fs.readFile('/package.json', 'utf-8');
//   readFile文件
const files = await webcontainerInstance.fs.readdir('/src');
// readdir读取目录
await webcontainerInstance.fs.rm('/src', { recursive: true });
// 删除目录
await webcontainerInstance.fs.writeFile('/src/main.js', 'console.log("Hello from WebContainers!")');
// 写文件
await webcontainerInstance.fs.mkdir('src');
// mkdir

2.2 Development Server

In einem WebContainer können Sie bei Bedarf einen HTTP-Server starten und erhalten eine Vorschau-URL, die mit dem Benutzer geteilt oder über einen Iframe direkt in der Anwendung angezeigt werden kann. Der virtualisierte TCP-Netzwerkstapel ist der ServiceWorker-API des Browsers zugeordnet und wird vollständig lokal ausgeführt, sodass der Server auch dann weiter funktioniert, wenn der Benutzer seine Internetverbindung verliert.

async function startDevServer() {
  // 执行 `npm run start` 启动Express服务器
  await webcontainerInstance.spawn('npm', ['run', 'start']);
  // 等待 `server-ready` 事件
  webcontainerInstance.on('server-ready', (port, url) => {
    iframeEl.src = url;
  });
}

In den Browser-Entwicklungstools können Sie nach dem Ausführen von startDevServer() im nächsten Schritt den laufenden Entwicklungsserver sehen:

WebContainer 1.0 ist erschienen! Lassen Sie uns darüber sprechen, was WebContainer sind!

Hinweis: WebContainer machen das Server-Ready-Ereignis verfügbar Wird verwendet, wenn der Server bereit ist. Wird ausgegeben, wenn eine Anfrage angenommen wird. Sie können webcontainerInstance.on verwenden, um auf Ereignisse zu warten.

2.3 Node.js-Befehlszeile

Node.js-Befehle können direkt an WebContainer übergeben werden, um sie beim Laden der Seite auszuführen oder durch Benutzeraktionen in der Anwendung auszulösen. Sie können mit npm Pakete installieren, einen neuen Knotenserver starten oder Anwendungen erstellen, genau wie in einer lokalen Entwicklungsumgebung.

webcontainerInstance.spawn('npm', ['install']);
webcontainerInstance.spawn('ls', ['src', '-l']);
// 安装依赖
async function installDependencies() {
  const installProcess = await webcontainerInstance.spawn('npm', ['install']);
  return installProcess.exit;
}
// 函数调用
window.addEventListener('load', async () => {
  textareaEl.value = files['index.js'].file.contents;
  webcontainerInstance = await WebContainer.boot();
  await webcontainerInstance.mount(files);
  const exitCode = await installDependencies();
  // 安装依赖
  if (exitCode !== 0) {
    throw new Error('Installation failed');
  };
});
WebContainer 1.0 ist erschienen! Lassen Sie uns darüber sprechen, was WebContainer sind!

总之,WebContainer API 为 Web 应用程序提供了更新级别的灵活性、可扩展性和性能!

3.使用 WebContainer API 构建什么?

stackblitz与社区成员密切合作并根据反馈、需求和问题开发了 WebContainers。 目前基于WebContainers的用例也越来越多,比如下面的经典用例:

3.1 交互式编码教程

Rich Harris 主导的 Svelte已经开始使用 WebContainers 。 他们构建了一个令人印象深刻的交互式教程,教您如何逐步使用 SvelteKit。 这是获得框架实践经验并了解其工作原理的好方法,同时获得了一致好评!

WebContainer 1.0 ist erschienen! Lassen Sie uns darüber sprechen, was WebContainer sind!

Svelte 是一种全新的构建用户界面的方法。传统框架如 React 和 Vue 在浏览器中需要做大量的工作,而 Svelte 将这些工作放到构建应用程序的编译阶段来处理。

与使用虚拟(virtual)DOM 差异对比不同。Svelte 编写的代码在应用程序的状态更改时就能像做外科手术一样更新 DOM。

3.2 生产级 Web IDE

StackBlitz使用 Webcontainers 构建了 Codeflow IDE,它是桌面 Visual Studio Code IDE 的全功能版本,支持 git 命令、桌面扩展和带终端的 Node.js 开发服务器。

WebContainer 1.0 ist erschienen! Lassen Sie uns darüber sprechen, was WebContainer sind!

3.3 人工智能应用

WebContainer API 还解锁了开发人员可以创建的一类新的 AI 应用程序。 想象一下使用 OpenAI 集成来生成完全在浏览器内运行的实时应用程序!

WebContainer 1.0 ist erschienen! Lassen Sie uns darüber sprechen, was WebContainer sind!

3.4 无代码/低代码环境

WebContainers 支持以前不可能实现的新型低代码或无代码解决方案。 StackBlitz的用户友好型文档编辑工具 Web Publisher 等工具确实使网络更加开放并打破了进入壁垒。

WebContainer 1.0 ist erschienen! Lassen Sie uns darüber sprechen, was WebContainer sind!

4.WebContainer的hello-world示例

应用配置环境:

export const projectFiles = {
  myProject: {
    directory: {
      'package.json': {
        file: {
          contents: '...',
        }
      },
      'index.js': {
        file: {
          contents: '...',
        }
      },
    }
  }
};

hello-world.ts程序:

import { WebContainer, FileSystemTree } from '@webcontainer/api';
import { projectFiles } from './project-files.ts';

async function main() {
  // 首先我们启动一个 WebContainer
  const webcontainer = await WebContainer.boot();
   // 启动容器后,我们复制所有项目文件
   // 进入容器的文件系统
  await webcontainer.mount(projectFiles);
   // 安装文件后,通过生成 `npm install` 来安装依赖
  const install = await webcontainer.spawn('npm', ['i']);
  await install.exit;
  // 一旦安装了所有依赖项,我们就可以生成 `npm`
  // 从项目的 `package.json` 运行 `dev` 脚本
  await webcontainer.spawn('npm', ['run', 'dev']);
}

5.本文总结

本文主要和大家介绍如何在浏览器中运行 Node.js,同时对WebContainer 1.0做了介绍,探讨了什么是WebContainers、WebContainers API 的主要功能 、使用 WebContainer API 应用场景等等!

WebContainers 非常适合交互式编码体验,可以用在生产级IDE,编程教程,下一代文档等场景。虽然看起来功能十分有限,却是从 0 到 1 的突破,尝试在浏览器端运行一个微型的操作系统,相信不久的未来,不仅仅是 nodejs,其他的语言,例如 python、Java等。

Das obige ist der detaillierte Inhalt vonWebContainer 1.0 ist erschienen! Lassen Sie uns darüber sprechen, was WebContainer sind!. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:toutiao.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen