rusty-svelte is an example project that how WebAssembly and Svelte could work together.
This example project uses:
Is for: The main focus of this project is to make an integration example of WebAssembly (Rust) and Svelte. Is not for: This project is neither a coding example from Rust nor from Svelte.
rusty-svelte
├── rust-project
└── svelte-project
Install the rollup-plugin-rust plugin.
Setup the plugin in your rollup.config.js
// ...
import rust from "@wasm-tool/rollup-plugin-rust";
export default [{
// ...
plugins: [
// ...
// Add the configuration for your wasm-tool plugins
// The generated .wasm file is placed in the /build/ folder.
// To tell the server where to fetch the .wasm file you have to specify
// the path otherwise you get a 404 error (.wasm file not found).
rust({
verbose: true,
serverPath: "/build/"
}),
]
}]
Access your wasm get_state
and dispatch
functions in your Svelte js code.
// svelte-app/src/main.js
import App from './App.svelte';
// Load the .toml file of your Rust project.
// The wasm-plugin runs `wasm-pack build` and cpoies the output into
// `svelte-app/target` directory.
// The `.wasm` file is located in the `svelte-app/public/build` dir.
import wasm from '../../rust-project/Cargo.toml';
// WebAssembly files must be loaded async.
const init = async () => {
const rustProject = await wasm();
const app = new App({
target: document.body,
props: {
// https://svelte.dev/docs#Creating_a_component
getState: rustProject.get_state(),
dispatch: rustProject.dispatch
}
});
};
init();
Start the server npm run dev
.
The output should look something like this:
Your application is ready~! 🚀
- Local: http://localhost:5000
────────────────── LOGS ──────────────────
[23:02:30] 200 ─ 5.79ms ─ /
[23:02:30] 200 ─ 1.51ms ─ /global.css
[23:02:30] 200 ─ 2.81ms ─ /build/bundle.css
[23:02:30] 200 ─ 3.40ms ─ /build/bundle.js
[23:02:31] 200 ─ 2.04ms ─ /build/rusty-svelte.wasm <-- The defined build path in your rollup.config.js file.
[23:02:31] 200 ─ 4.86ms ─ /build/bundle.css.map
[23:02:31] 200 ─ 7.84ms ─ /build/bundle.js.map
[23:02:31] 200 ─ 1.20ms ─ /favicon.png