The Rust WebAssembly tooling is something of a miracle. I can write normal Rust code, sprinkle in a few binding annotations and, for the most part, it just works™. It even integrates quite nicely with TypeScript types, Web APIs and Promises/async.
However, just as you’re settling in with a slice of cake and glass of lemonade to write some Rust code for your web application, one class of problem is waiting to come and stomp all over your nice, type-safe picnic.
The key library used for generating JavaScript bindings, wasm-bindgen, papers over this difference. Whether you use owned values or references, they look identical from JavaScript-land. However, many rules are enforced at runtime - the worst time to discover that your code is wrong.
Let’s look at a couple of common pitfalls. The full code for these examples can be found in the rust-wasm-pitfalls repository.
Since Rust doesn’t have a garbage collector, it needs other techniques for knowing when to clean things up. If a value is owned, it can be in one of two states at the end of the function: