JSPM

  • Created
  • Published
  • Downloads 140
  • Score
    100M100P100Q91580F
  • License MIT

wasm-pack plugin for vite@v2

Package Exports

  • vite-plugin-rsw

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (vite-plugin-rsw) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

vite-plugin-rsw

npm npm downloads vite version chat

Rust WebAssembly

wasm-pack plugin for vite@v2

Pre-installed

Features

  • startup optimization
  • mode: development build or release build
  • generate npm package(library)
  • compile error is displayed on the page(hot-update)
  • multiple rust crate
    • compile
    • hot-update
rsw run

Quick Start

create-xc-app: create a project in seconds!

template: wasm-vue3 and wasm-react

# With NPM
npm init xc-app

# With Yarn:
yarn create xc-app

# -------------------

# command line options
npm init xc-app my-wasm-app --template wasm-react

Getting Started

Step1

# install rsw
npm i -D vite-plugin-rsw

# or
yarn add -D vite-plugin-rsw
// vite.config.ts
import { defineConfig } from "vite";
import ViteRsw from "vite-plugin-rsw";

export default defineConfig({
  plugins: [
    ViteRsw({
      // unLinks: [],
      // isLib: false,
      // libRoot: 'libs',
      mode: "release",
      crates: ["@rsw/hey", "rsw-test"],
    }),
  ],
});

Step2

# example:
#   npm package: `cargo new --lib rsw-test`
#   npm org    : `cargo new --lib @rsw/hey`
cargo new --lib <crate_name>
# Cargo.toml

# https://github.com/rustwasm/wasm-pack/issues/886
# https://developers.google.com/web/updates/2019/02/hotpath-with-wasm
[package.metadata.wasm-pack.profile.release]
wasm-opt = false

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[lib]
crate-type = ["cdylib", "rlib"]

[profile.release]
lto = true
opt-level = "s"

[dependencies]
wasm-bindgen = "0.2.70"
// src/lib.rs
use wasm_bindgen::prelude::*;

// Import the `window.alert` function from the Web.
#[wasm_bindgen]
extern "C" {
    fn alert(s: &str);
}

// Export a `greet` function from Rust to JavaScript, that alerts a hello message.
#[wasm_bindgen]
pub fn greet(name: &str) {
    alert(&format!("Hello, {}!", name));
}

Plugin Options

  • mode
    • dev: (default) create a development build. Enable debug info, and disable optimizations.
    • release: create a release build. Enable optimizations and disable debug info.
  • target: sets the target environment.
    • web: (default)
    • bundler
    • nodejs
    • no-modules
  • unLinks: string[] - (npm unlink) uninstalls a package.
  • isLib: boolean - whether to generate npm package, the default value is false.
  • libRoot: string - the root path of the npm package, the default value is libs.
  • crates: string[] - (npm link) package name, support npm organization.

⚠️ Note: Before performing the vite build, at least once vite dev, generate wasm package (rust-crate/pkg). In the project, wasm package is installed by vite-plugin-rsw in the form of npm link, otherwise it will error Can not find module 'rust-crate' or its corresponding type declarations.

Examples

微信

群二维码已过期,关注公众号《浮之静》,发送“进群”,我将拉你进群一起学习。

wasm-wechat-qrcode fzj-qrcode

License

MIT License © 2021 lencx