WebAssembly - конвертировать WAT в WASM
В предыдущей главе мы увидели, как писать код на .watт.е. текстовый формат WebAssembly. Текстовый формат WebAssembly не будет работать напрямую в браузере, и вам необходимо преобразовать его в двоичный формат, то есть WASM, чтобы работать в браузере.
WAT в WASM
Давайте конвертируем .WAT в .WASM.
Код, который мы собираемся использовать, выглядит следующим образом:
(module
(func $add (param $a i32) (param $b i32) (result i32)
get_local $a
get_local $b
i32.add
)
(export "add" (func $add))
)
Теперь перейдите к WebAssembly Studio, который доступен по адресу https://webassembly.studio/.
Вы должны увидеть что-то вроде этого, когда нажмете ссылку -
Щелкните Пустой проект Wat и нажмите кнопку Создать внизу.
Это приведет вас к пустому проекту, как показано ниже -
Щелкните main.wat, замените существующий код своим и нажмите кнопку сохранения.
После сохранения щелкните сборку, чтобы преобразовать ее в .wasm -
Если сборка прошла успешно, вы должны увидеть файл .wasm, созданный, как показано ниже -
Откройте файл main.wasm и используйте его внутри своего .html файла, чтобы увидеть результат, как показано ниже.
Например - add.html
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>WebAssembly Add Function</title>
</head>
<body>
<script>
let sum;
fetch("main.wasm")
.then(bytes => bytes.arrayBuffer())
.then(mod => WebAssembly.compile(mod)) .then(module => {
return new WebAssembly.Instance(module)
})
.then(instance => {
sum = instance.exports.add(10,40);
console.log("The sum of 10 and 40 = " +sum);
});
</script>
</body>
</html>
Функция add экспортируется, как показано в коде. Переданные параметры - это 2 целых числа 10 и 40, и он возвращает их сумму.
Вывод
Результат отображается в браузере.