What is AssemblyScript?

jairussw

JairusSW

Posted on July 12, 2021

What is AssemblyScript?

Alt Text
AssemblyScript β€” a variant of TypeScript that compiles to WebAssembly. Since it is compiled, it outperforms JavaScript in some cases. AS follows the TypeScript syntax as closely as possible and even adds more features to it. AssemblyScript allows us to write fast WebAssembly for the Web and Server without learning another language.

AssemblyScript is very easy to use. All you need to do is install it via NPM.

Try it out online: Online editor

~ npm i assemblyscript --save-dev
~ npx asinit .
~ npm i
Enter fullscreen mode Exit fullscreen mode

What did that do? First of all, it installed both the loader and the compiler. Secondly, it made a template project with an add function. Now, we just need to compile it to WebAssembly.

~ npm run asbuild
Enter fullscreen mode Exit fullscreen mode

So, if you check out the /build folder, there are the .wasm files that were built. NodeJS and JavaScript both provide a way to run WebAssembly files and AssemblyScript provides its own loader to work with the code. To start our code, we need another file

test.js

const wasmModule = require('./index')
// This works just like a normal module
console.log(wasmModule.add(2,9))
// -- 11
Enter fullscreen mode Exit fullscreen mode

Now, run it!

~ node test.js
Enter fullscreen mode Exit fullscreen mode

It should have outputted the number 11.

JavaScript code for the add function would look like this:

function add(a, b) {
    return a + b
}
module.exports = {
    add: add
}
Enter fullscreen mode Exit fullscreen mode

The AssemblyScript code looks like this:

export function add(a: i32, b: i32): i32 {
    return a + b;
}
Enter fullscreen mode Exit fullscreen mode

Pretty similar, right? When we compile it, we can require it just like a normal JavaScript file. Keep in mind that WebAssembly is sandboxed which means it can’t access the system, make HTTP requests, or log to the console. However, AssemblyScript supports both WASI and JS bindings (calling JS from AS).

If you have any questions or comments, feel free to comment or join the AssemblyScript Discord. Or, check out the website.πŸ˜‰

P.S: There is a tutorial at https://jtanaka.gitbook.io/guide/

πŸ’– πŸ’ͺ πŸ™… 🚩
jairussw
JairusSW

Posted on July 12, 2021

Join Our Newsletter. No Spam, Only the good stuff.

Sign up to receive the latest update from our blog.

Related

What is AssemblyScript?
javascript What is AssemblyScript?

July 12, 2021