如何构建支持多个捆绑机的WebAssembly软件包?
我想使用JavaScript(Typescript) + WebAssembly(Rust)构建混合库(IE NPM软件包)。我想支持多个捆绑包,而不仅仅是webpack。这似乎很困难,因为每个Bundler都使用一种略有不同的方法来导入WASM:
// Webpack (experiments.asyncWebAssembly)
import { hello } from './my-lib.wasm'
hello()
// Rollup (using @rollup/plugin-wasm)
import init from './my-lib.wasm'
init().then(({ instance }) => { instance.exports.hello() })
// Parcel
import { hello } from './my-lib.wasm'
hello()
// ...or, if you want a promise
import('./my-lib.wasm').then(exports => { exports.hello() })
// Vite (note: this will be removed in v3.0,
// see https://github.com/vitejs/vite/discussions/7763)
import init from './my-lib.wasm'
init().then(exports => { exports.hello() })
// alternatively, use vite-plugin-wasm, which is the preferred approach for v3+
import { hello } from './my-lib.wasm'
hello()
我不能依靠Wasm-Bindgen生成的JS绑定,因为Afaik仅与WebPack兼容。
// JS bindings generated by wasm-bindgen
import * as wasm from './my-lib_bg.wasm'
export function hello() { wasm.hello() }
Web应用程序没有这个问题,因为他们可以选择自己的捆绑器 - 但我不知道Bundler会事先处理我的代码。
如何编写支持多个捆绑机的软件包?我可以以某种方式为每个捆绑器生成不同的入口点吗?
I want to build a hybrid library (i.e. NPM package) using JavaScript (TypeScript) + WebAssembly (Rust). And I want to support multiple bundlers, not just Webpack. This seems difficult, since each bundler uses a slightly different approach for importing WASM:
// Webpack (experiments.asyncWebAssembly)
import { hello } from './my-lib.wasm'
hello()
// Rollup (using @rollup/plugin-wasm)
import init from './my-lib.wasm'
init().then(({ instance }) => { instance.exports.hello() })
// Parcel
import { hello } from './my-lib.wasm'
hello()
// ...or, if you want a promise
import('./my-lib.wasm').then(exports => { exports.hello() })
// Vite (note: this will be removed in v3.0,
// see https://github.com/vitejs/vite/discussions/7763)
import init from './my-lib.wasm'
init().then(exports => { exports.hello() })
// alternatively, use vite-plugin-wasm, which is the preferred approach for v3+
import { hello } from './my-lib.wasm'
hello()
I can't rely on JS bindings generated by wasm-bindgen, since AFAIK it is only compatible with Webpack.
// JS bindings generated by wasm-bindgen
import * as wasm from './my-lib_bg.wasm'
export function hello() { wasm.hello() }
Web apps don’t have this problem because they can choose their own bundler--but I don't know what bundler will process my code in advance.
How can I write a package that supports multiple bundlers? Can I somehow generate different entry points for each bundler?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
我认为
bundler
目标是未来的答案,即使用 wasm esm esm Integration 。它目前由WebPack和Vite(您提到的我提到的插件)支持。将来,浏览器和node.js中会有本机支持。但是目前可能需要创建插件来在其他捆绑机中支持它们。目前的另一个选择是使用
Web
目标,该目标要求您的软件包的用户从Bundler获取WASM文件的URL并使用它初始化插件。I think the
bundler
target is the answer for the future, i.e. with WASM ESM integration. It's currently supported by Webpack and Vite (with my plugin you mentioned). In the future there'll be native support in browser and Node.js. But currently plugins may be needed to be created to support them in other bundlers.Another option for now is to use the
web
target, which requires your package's user to obtain the WASM file's URL from the bundler and initialize your plugin with it.