最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - How to load .wasm file in React-Native? - Stack Overflow

programmeradmin2浏览0评论

I have been trying to load a WebAssembly (.wasm) file - generated C++ code piled to WebAssembly by Emscripten - in a React-Native app.

This is my code to fetch the .wasm file:

import fs from 'react-native-fs';

if (!global.WebAssembly) {
  global.WebAssembly = require('webassemblyjs');
}

const fetchWasm = async () => {
  const wasm = await fetch(`${fs.MainBundlePath}/calculator.wasm`);

  console.log(wasm);
  // Returns: Response {type: "default", status: 200, ok: true, statusText: undefined, headers: Headers, …}

  const mod = await WebAssembly.instantiateStreaming(wasm);

  console.log(mod);
  // Throws: TypeError: Failed to execute 'pile' on 'WebAssembly': An argument must be provided, which must be a Response or Promise<Response> object
};

I tried everything in the Google search results I could find, but nothing worked so far. Unfortunately, the most related questions were unanswered.

Is there anyone who knows what I am doing wrong? Any help would be greatly appreciated!

I have been trying to load a WebAssembly (.wasm) file - generated C++ code piled to WebAssembly by Emscripten - in a React-Native app.

This is my code to fetch the .wasm file:

import fs from 'react-native-fs';

if (!global.WebAssembly) {
  global.WebAssembly = require('webassemblyjs');
}

const fetchWasm = async () => {
  const wasm = await fetch(`${fs.MainBundlePath}/calculator.wasm`);

  console.log(wasm);
  // Returns: Response {type: "default", status: 200, ok: true, statusText: undefined, headers: Headers, …}

  const mod = await WebAssembly.instantiateStreaming(wasm);

  console.log(mod);
  // Throws: TypeError: Failed to execute 'pile' on 'WebAssembly': An argument must be provided, which must be a Response or Promise<Response> object
};

I tried everything in the Google search results I could find, but nothing worked so far. Unfortunately, the most related questions were unanswered.

Is there anyone who knows what I am doing wrong? Any help would be greatly appreciated!

Share Improve this question asked Mar 13, 2020 at 16:11 Joris van DongenJoris van Dongen 2112 silver badges3 bronze badges 6
  • According to the docs WebAssembly.instantiateStreaming, returns a promise. In order to retrieve its output i think you need to add a .then() – Kevin Hernandez Commented Mar 13, 2020 at 16:13
  • 2 I use the await to get the result of the Promise and assign it to the 'mod' variable. – Joris van Dongen Commented Mar 13, 2020 at 16:33
  • Try: const mod = await WebAssembly.instantiateStreaming(wasm).then(mod => console.log(mod)); – Kevin Hernandez Commented Mar 13, 2020 at 16:35
  • Just a wild guess because I think I've ran into a similar issue before. I think your wasm variable is not an actual object, otherwise console.log would not append "Response" to the beginning. You probably need to use JSON.parse(wasm). – Tom Daniel Commented Sep 8, 2020 at 0:17
  • Did you manage to get this working? – Kay Commented Mar 6, 2021 at 10:07
 |  Show 1 more ment

3 Answers 3

Reset to default 2

There is one thing to be aware when wanting to load wasm :

Your webserver must report .wasm mime type as "application/wasm" , otherwise you won't be able loading it.

I assume still React-native JS runtime JSC still not support WebAssembly in Android build the issue is still open https://github./react-native-munity/jsc-android-buildscripts/issues/113

Another way is to use Webview but I assume it is not you are expecting. https://github./ExodusMovement/react-native-wasm

react-native-webassembly looks promising:

This package enables WebAssembly for React Native powered by C++ TurboModules and Wasm3, a fast and universal WebAssembly runtime.

发布评论

评论列表(0)

  1. 暂无评论