Dự án nguồn mở của ứng dụng nhỏ

kbone

Dự án kbone (nguồn mở trên GitHub) triển khai bộ chuyển đổi mô phỏng môi trường trình duyệt trong lớp thích ứng để mã viết cho web có thể chạy mà không cần thay đổi trong ứng dụng nhỏ. Một số mẫu khởi động (trong số đó có Vue, ReactPreact) tồn tại giúp trải nghiệm làm quen của nhà phát triển web qua các khung này dễ dàng hơn.

Bạn có thể tạo dự án mới bằng công cụ kbone-cli. Trình hướng dẫn sẽ hỏi khung để bắt đầu dự án. Đoạn mã dưới đây cho thấy bản minh hoạ Preact. Trong đoạn mã dưới đây, lệnh mp tạo ứng dụng nhỏ, lệnh web tạo ứng dụng web và build tạo ứng dụng web chính thức.

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

Đoạn mã dưới đây cho thấy một thành phần bộ đếm đơn giản sau đó được kết xuất đẳng hình trong ứng dụng nhỏ và ứng dụng web. Mức hao tổn của ứng dụng thu nhỏ là rất đáng kể, chỉ khi đánh giá cấu trúc 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;
Ứng dụng minh hoạ mẫu kbone Preact đã mở trong Công cụ cho nhà phát triển của WeChat. Việc kiểm tra cấu trúc DOM cho thấy mức hao tổn đáng kể so với ứng dụng web.
Ứng dụng minh hoạ mẫu kbone Preact đã mở trong Công cụ cho nhà phát triển của WeChat. Hãy lưu ý cấu trúc DOM phức tạp và cách các nút dấu cộng và dấu trừ thực ra không phải là phần tử <button>.
Ứng dụng minh hoạ mẫu Preact kbone đã mở trong trình duyệt web. Việc kiểm tra cấu trúc DOM sẽ hiển thị đánh dấu dự kiến dựa trên mã thành phần Preact.
Ứng dụng minh hoạ mẫu Preact kbone được mở trong trình duyệt web. Hãy ghi lại cấu trúc DOM.

kbone-ui

Dự án kbone-ui (nguồn mở trên GitHub) là khung giao diện người dùng hỗ trợ cả việc phát triển ứng dụng nhỏ lẫn phát triển Vue.js bằng kbone. Các thành phần kbone-ui mô phỏng giao diện của các thành phần ứng dụng nhỏ tích hợp sẵn trong WeChat (xem thêm phần Các thành phần ở trên). Bản minh hoạ chạy trực tiếp trong trình duyệt cho phép bạn khám phá các thành phần có sẵn.

Bản minh hoạ khung kbone-ui hiển thị các thành phần có liên quan đến biểu mẫu như nút chọn, công tắc, dữ liệu đầu vào và nhãn.
Bản minh hoạ kbone-ui hiển thị các thành phần có liên quan đến biểu mẫu.

WeUI

WeUI là một tập hợp các thư viện kiểu cơ bản, phù hợp với trải nghiệm hình ảnh mặc định của WeChat. Nhóm thiết kế chính thức của WeChat đã thiết kế riêng cho các trang web nội bộ của WeChat và các ứng dụng nhỏ của WeChat nhằm giúp cho nhận thức của người dùng về việc sử dụng các ứng dụng này trở nên thống nhất hơn. API này bao gồm các thành phần như button, cell, dialog, progress, toast, article, actionsheeticon. Có nhiều phiên bản WeUI như weui-wxss cho các ứng dụng nhỏ trên WeChat được tạo kiểu bằng WXSS (xem phần Định kiểu ở trên), weui.js cho ứng dụng web và react-weui cho các thành phần Phản ứng WeChat.

Bản minh hoạ khung WeUI cho thấy các thành phần liên quan đến biểu mẫu, cụ thể là các nút chuyển.
Ứng dụng minh hoạ WeUI hiển thị các nút chuyển.

Omi

Omi là một khung giao diện người dùng tự xác nhận quyền sở hữu trên nhiều khung (nguồn mở trên GitHub.) Công cụ này hợp nhất các Thành phần web, JSX, DOM ảo, kiểu chức năng, trình quan sát hoặc Proxy vào một khung với kích thước nhỏ và hiệu suất cao. Mục tiêu của API này là cho phép nhà phát triển viết các thành phần một lần và sử dụng các thành phần đó ở mọi nơi, chẳng hạn như Omi, React, Preact, Vue.js hoặc Angular. Việc viết các thành phần Omi rất trực quan và không có gần như tất cả các mã nguyên mẫu.

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");

Tiếng Omiu

Omiu là một thư viện thành phần giao diện người dùng trên nhiều khung (nguồn mở trên GitHub) được phát triển dựa trên Omi, cho ra các phần tử tuỳ chỉnh của các thành phần web tiêu chuẩn.

Bản minh hoạ khung Omiu cho thấy các thành phần liên quan đến biểu mẫu, cụ thể là nút chuyển.
Ứng dụng minh hoạ Omiu cho thấy các nút chuyển.

WePY

WePY là một khung cho phép các ứng dụng nhỏ hỗ trợ quá trình phát triển theo thành phần. Thông qua quá trình biên dịch trước, nhà phát triển có thể chọn kiểu phát triển yêu thích của họ để phát triển các ứng dụng nhỏ. Việc tối ưu hoá chi tiết khung cũng như việc giới thiệu Promise cũng như các hàm không đồng bộ đều giúp việc phát triển các dự án ứng dụng nhỏ trở nên dễ dàng và hiệu quả hơn. Đồng thời, WePY cũng là một khung đang phát triển, chủ yếu tiếp nhận một số công cụ giao diện người dùng được tối ưu hoá cũng như các khái niệm và ý tưởng thiết kế khung, chủ yếu từ 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>
Trang tài liệu &#39;bắt đầu&#39; của WePY hiển thị các bước đầu tiên để bắt đầu.
Tài liệu "bắt đầu sử dụng" WePY.

vConsole

Dự án vConsole cung cấp một công cụ gọn nhẹ dành cho nhà phát triển giao diện người dùng có thể mở rộng và dùng cho các trang web dành cho thiết bị di động. Công cụ này cung cấp trình gỡ lỗi giống Công cụ cho nhà phát triển có thể được chèn trực tiếp vào các ứng dụng web và ứng dụng nhỏ. Bản minh hoạ cho thấy các cơ hội. vConsole bao gồm các thẻ cho nhật ký, hệ thống, mạng, phần tử và bộ nhớ.

Ứng dụng minh hoạ vConsole. vConsole sẽ xuất hiện ở dưới cùng và có các thẻ về nhật ký, hệ thống, mạng, phần tử và bộ nhớ.
Ứng dụng minh hoạ của vConsole hiển thị trình khám phá phần tử.

web

Dự án weweb (nguồn mở trên GitHub) là khung giao diện người dùng cơ bản của khung ứng dụng nhỏ của Hera tuyên bố là tương thích với cú pháp của các ứng dụng nhỏ WeChat, vì vậy, bạn có thể viết ứng dụng web theo cách ứng dụng nhỏ. Tài liệu này hứa hẹn rằng nếu đã có một ứng dụng nhỏ, bạn có thể chạy ứng dụng đó trong trình duyệt nhờ web. Trong các thử nghiệm của tôi, tính năng này hoạt động không ổn định đối với các ứng dụng nhỏ hiện tại, có thể là do gần đây dự án không thấy các bản cập nhật khiến trình biên dịch bỏ lỡ các thay đổi trong nền tảng WeChat.

Tài liệu về khung ứng dụng nhỏ của Hera liệt kê các API WeChat mà khung hỗ trợ như &quot;wx.request&quot;, &quot;wx.uploadFile&quot;, v.v.
Tài liệu về khung ứng dụng nhỏ của Hera hiển thị danh sách các API WeChat được hỗ trợ.
Ứng dụng nhỏ minh hoạ trên web giới thiệu được biên dịch với Weweb để chạy trong trình duyệt hiển thị các thành phần biểu mẫu.
Ứng dụng nhỏ minh hoạ trên web được biên dịch với weweb để chạy trong trình duyệt.

Xác nhận

Bài viết này đã được Joe Medley, Kayce Basques, Milica Mihajlija, Alan Kent và Keith Gu xem xét.