迷你应用开源项目

kbone

kbone 项目(GitHub 上的开源项目)实现了一个适配器,该适配器可在适配层中模拟浏览器环境,以便为 Web 编写的代码无需更改即可在小程序中运行。目前有多个入门模板(包括 VueReactPreact),可帮助来自这些框架的 Web 开发者更轻松地开始使用 kbone。

您可以使用 kbone-cli 工具创建新项目。向导会询问要使用哪个框架来启动项目。以下代码段展示了 Preact 演示。在下面的代码段中,mp 命令用于构建小程序,web 命令用于构建 Web 应用,而 build 用于创建生产 Web 应用。

npx kbone-cli init my-app
cd my-app
npm run mp
npm run web
npm run build

以下代码段展示了一个简单的计数器组件,该组件随后在小程序和 Web 应用中以同构方式呈现。仅从 DOM 结构来看,小程序的开销非常大。

import { h, Component } from "preact";
import "./index.css";

class Counter extends Component {
  state = { count: 1 };

  sub = () => {
    this.setState((prevState) => {
      return { count: --prevState.count };
    });
  };

  add = () => {
    this.setState((prevState) => {
      return { count: ++prevState.count };
    });
  };

  clickHandle = () => {
    if ("undefined" != typeof wx && wx.getSystemInfoSync) {
      wx.navigateTo({
        url: "../log/index?id=1",
      });
    } else {
      location.href = "log.html";
    }
  };

  render({}, { count }) {
    return (
      <div>
        <button onClick={this.sub}>-</button>
        <span>{count}</span>
        <button onClick={this.add}>+</button>
        <div onClick={this.clickHandle}>跳转</div>
      </div>
    );
  }
}

export default Counter;
在微信开发者工具中打开了 Preact kbone 模板演示版应用。检查 DOM 结构发现,与 Web 应用相比,开销明显偏高。
在微信开发者工具中打开的 Preact kbone 模板演示版应用。请注意复杂的 DOM 结构,以及加号和减号按钮实际上不是 <button> 元素。
Preact kbone 模板演示版应用已在网络浏览器中打开。检查 DOM 结构会发现,标记与基于 Preact 组件代码的预期标记一致。
Preact kbone 模板演示版应用已在网络浏览器中打开。请注意 DOM 结构。

kbone-ui

kbone-ui 项目(GitHub 上的开源项目)是一个界面框架,可帮助您使用 kbone 进行小程序开发和 Vue.js 开发。kbone-ui 组件可模拟 微信的内置小程序组件的外观和风格(另请参阅上文中的组件)。通过直接在浏览器中运行的演示,您可以探索可用的组件。

演示 kbone-ui 框架,展示与表单相关的组件,例如单选按钮、开关、输入和标签。
显示与表单相关的组件的 kbone-ui 演示。

WeUI

WeUI 是一组与微信的默认视觉体验一致的基本样式库。微信官方设计团队为微信内部网页和微信小程序量身定制了设计,以使用户的使用感知更加统一。它包括 buttoncelldialogprogresstoastarticleactionsheeticon 等组件。WeUI 有不同的版本,例如 weui-wxss(用于使用 WXSS 设置样式的微信小程序,请参阅上文中的样式设置)、weui.js(用于 Web 应用)和 react-weui(用于微信 React 组件)。

WeUI 框架的演示,展示了与表单相关的组件,即开关。
显示开关的 WeUI 演示版应用。

Omi

Omi 是一个自称的“前端跨框架框架”(在 GitHub 上开源。它将 Web 组件、JSX、虚拟 DOM、函数式风格、观察者或代理合并到一个框架中,具有体积小、性能高的特点。其目的是让开发者编写一次组件,即可在任何地方使用,例如 Omi、React、Preact、Vue.js 或 Angular。编写 Omi 组件非常直观,几乎不需要任何样板代码。

import { render, WeElement, define } from "omi";

define("my-counter", class extends WeElement {
  data = {
    count: 1,
  };

  static css = `
    span{
        color: red;
    }`;

  sub = () => {
    this.data.count--;
    this.update();
  };

  add = () => {
    this.data.count++;
    this.update();
  };

  render() {
    return (
      <div>
        <button onClick={this.sub}>-</button>
        <span>{this.data.count}</span>
        <button onClick={this.add}>+</button>
      </div>
    );
  }
});

render(<my-counter />, "body");

Omiu

Omiu 是基于 Omi 开发的跨框架界面组件库(GitHub 上的开源项目),可输出标准 Web 组件的自定义元素。

Omiu 框架的演示,显示了与表单相关的组件,即开关。
显示开关的 Omiu 演示版应用。

WePY

WePY 是一个框架,可让小程序支持组件化开发。通过预编译,开发者可以选择自己喜欢的开发风格来开发小程序。框架的详细优化以及 Promise 和异步函数的引入,都使得小程序项目的开发更加轻松高效。与此同时,WePY 也是一个不断发展的框架,它在很大程度上吸收了一些优化的前端工具和框架设计概念和想法,其中大部分来自 Vue.js。

<style lang="less">
  @color: #4d926f;
  .num {
    color: @color;
  }
</style>

<template>
  <div class="container">
    <div class="num" @tap="num++">{{num}}</div>
    <custom-component></custom-component>
    <vendor-component></vendor-component>
    <div>{{text}}</div>
    <input v-model="text" />
  </div>
</template>

<config>
  { usingComponents: { customComponent: '@/components/customComponent', vendorComponent:
  'module:vendorComponent' } }
</config>

<script>
  import wepy from "@wepy/core";

  wepy.page({
    data: {
      num: 0,
      text: "Hello World",
    },
  });
</script>
WePY“使用入门”文档页面,其中显示了开始使用的第一步。
WePY“入门”文档。

vConsole

vConsole 项目为移动网页提供了一款轻量级、可扩展的前端开发者工具。它提供了一个类似于开发者工具的调试器,可以直接注入到 Web 应用和小程序中。演示展示了各种机会。vConsole 包含用于显示日志、系统、网络、元素和存储空间的标签页。

vConsole 演示版应用。vConsole 在底部打开,并包含用于日志、系统、网络、元素和存储空间的标签页。
vConsole 演示版应用,显示元素浏览器。

weweb

weweb 项目(GitHub 上的开源项目)是 Hera 小程序框架的底层前端框架,该框架声称与微信小程序的语法兼容,因此您可以像编写小程序一样编写 Web 应用。该文档承诺,如果您已有小程序,则可以借助 weweb 在浏览器中运行它。在我的实验中,此方法对当前的微应用并不适用,很可能是因为项目最近没有更新,导致其编译器错过了微信平台中的更改。

Hera 小程序框架的文档,其中列出了它支持的微信 API,例如 `wx.request`、`wx.uploadFile` 等。
Hera 小程序框架文档,其中显示了受支持的微信 API 列表。
使用 weweb 编译的 weweb 演示迷你应用,可在浏览器中运行,显示表单元素。
使用 weweb 编译的 weweb 演示版微应用,可在浏览器中运行。

致谢

本文已由以下人员审核:Joe MedleyKayce BasquesMilica MihajlijaAlan Kent 和 Keith Gu。