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
wasm-pack plugin for vite@v2
Pre-installed
Remote deployment project
Use lencx/rsw-node
# install rsw
npm i -D rsw-node
# or
yarn add -D rsw-nodeFor example:
-
"scripts": { "rsw:deploy": "rsw && npm run build" }
-
{ "root": ".", "crates": [ "@rsw/chasm", "@rsw/game-of-life", "@rsw/excel-read" ] }

Features
- startup optimization
- mode:
development buildorrelease build - enable debub mode:
DEBUG=rsw yarn dev - generate npm package(library)
- friendly error message: browser and terminal
- multiple rust crate
- compile
- hot-update



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-reactGetting 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({
// root: '',
// unLinks: [],
// isLib: false,
// libRoot: 'libs',
mode: 'dev',
crates: [
'@rsw/hey',
'rsw-test',
// https://github.com/lencx/vite-plugin-rsw/issues/8#issuecomment-820281861
// outDir: use `path.resolve` or relative path.
{ name: '@rsw/hello', outDir: 'custom/path' },
],
}),
],
});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
root: rust crate root path. default project root path.modedev: (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)bundlernodejsno-modules
unLinks:string[]- (npm unlink) uninstalls a package.isLib:boolean- whether to generate npm package, the default value isfalse.libRoot:string- the root path of the npm package, the default value islibs.crates: Item[ ] - (npm link) package name, support npm organization.- Item as string -
'@rsw/hello' - Item as RswCrateOptions -
{ name: '@rsw/hello', outDir: 'custom/path' }
- Item as string -
⚠️ Note: Before performing the
vite build, at least oncevite dev, generatewasm package (rust-crate/pkg). In the project,wasm packageis installed byvite-plugin-rswin the form ofnpm link, otherwise it will errorCan not find module 'rust-crate' or its corresponding type declarations.
Error
npm ERR! EEXIST: file already exists
# https://docs.npmjs.com/cli/v6/commands/npm-link # npm link uses the global prefix (see npm prefix -g for its value) # /Users/lencx/.nvm/versions/node/v15.6.0 npm prefix -g # after removing the folder, try again `npm run dev` rm -rf /Users/lencx/.nvm/versions/node/v15.6.0/lib/node_modules/@rsw/chasm

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

License
MIT License © 2021 lencx