SlideShare a Scribd company logo
INTRODUCTION TO
WEBASSEMBLY
GABRIELE FALASCA - MOZILLA - ROMAJS
WHO AM I?
● GABRIELE FALASCA
● Frontend developer @Sourcesense
● Mozilla Tech Speaker
● Mozillian
● Open source Addicted
● Linux user since 2009
DISCLAIMER
HISTORY
HISTORY:
1995 2005 TODAY
/index.html /index.php /api/v1/post?page=1&orderby=name
Static HTML content HTML content generated
from PHP (or ASP or
Java) application
Semi-raw data in a
browser understandable
format (someone says
JSON?)
Javascript is born (1997~1999 )
FOCUS:
JAVASCRIPT IS THE ONLY LANGUAGE THAT WEB
BROWSERS CAN RUN
FOCUS:
JAVASCRIPT WAS ORIGINALLY CREATED FOR MANAGE
USER INTERACTION WITH THE DOM, BUT NOW YOU
CAN WRITE COMPLETE WEB APPLICATION WITH IT.
FOCUS:
TODAY THE BROWSER HAS TO WORK HARD FOR
ELABORATE DATA AND RENDER WEBPAGES!!!
HOW TO AVOID LAGS?
HOW TO AVOID LAGS:
JS FRAMEWORK
HOW TO AVOID LAGS:
PRECOMPILATION
NEXT STEP
NEXT STEP:
CAN CLIENT-SIDE WEBAPPLICATION RUN AT
HARDWARE-NATIVE SPEED?
NEXT STEP:
SOMEONE ARE WORKING ON IT!! :D
WHO IS:
WEBASSEMBLY IS A NEW PORTABLE, SIZE- AND
LOAD-TIME-EFFICIENT FORMAT SUITABLE FOR
COMPILATION TO THE WEB
from: WebAssembly.org
WHO IS:
IS A NEW LOW-LEVEL ASSEMBLY-LIKE LANGUAGE
THAT RUNS IN MODERN BROWSERS AT NEAR-NATIVE
PERFORMANCE
from: WebAssembly.org
WHAT?!
WHAT?!
WEBASSEMBLY IS NOT A BINARY BLOB COLLECTION
LAUNCHED IN YOUR BROWSER!!!
IS A SORT OF HUMAN-READABLE CODE RUNTIME
COMPILED
ANOTHER LANGUAGE?!
ANOTHER LANGUAGE?!
YOU CAN WRITE YOUR C/C++ CODE AND COMPILE IT
TO WEBASSEMBLY MODULE.
ANOTHER LANGUAGE?!
WEBASSEMBLY MODULES CAN BE WRAPPED INTO
JAVASCRIPT FUNCTIONS (AND CAN USE EXISTING JS
LIBRARIES)
JS API
JS API
WEBASSEMBLY MODULES CAN BE WRAPPED INTO
JAVASCRIPT FUNCTIONS (AND CAN USE EXISTING JS
LIBRARIES)
var mod = new WebAssembly.Module(BufferSource bytes) - (now)
---
<script type=”module” src=”somepath/wasmpath”></script> - (in the future)
BufferSource object is not a web standard at now
JS WebAssembly Object
JS WebAssembly Object - constructors
WebAssembly.Module
WebAssembly.Instance
WebAssembly.Memory
WebAssembly.Table
WebAssembly.CompileError
WebAssembly.LinkError
WebAssembly.RuntimeError
JS WebAssembly Object - functions
WebAssembly.validate(BufferSource bs)
WebAssembly.compile(BufferSource bs) - async
WebAssembly.instantiate(Module m)
Complete specifications to: http://webassembly.org/docs/js/
New JS Types
New JS Types
Uint8Array
Uint16Array
Uint32Array
these types are not standard at this moment, but they are in Release Candidate state for standardization
BACKWARD COMPATIBILITY?!
BACKWARD COMPATIBILITY?!
POLYFILL!
EXAMPLES
EXPLORER
EPICZENGARDEN
SOME QT PROJECTS PORTED TO WEBASSEMBLY
QUESTIONS?!

More Related Content

PDF
WebAssembly Demystified
Jay Phelps
 
PPTX
WebAssembly: In a Nutshell
RangHo Lee
 
PDF
Is WebAssembly the killer of JavaScript?
Boyan Mihaylov
 
PPTX
Web assembly - Future of the Web
CodeValue
 
PDF
WebAssembly Overview
Alexandr Skachkov
 
PPTX
Teaching Machine Learning with Physical Computing - July 2023
Hal Speed
 
ODP
An Introduction to WebAssembly
Daniel Budden
 
PDF
Hacking ansible
bcoca
 
WebAssembly Demystified
Jay Phelps
 
WebAssembly: In a Nutshell
RangHo Lee
 
Is WebAssembly the killer of JavaScript?
Boyan Mihaylov
 
Web assembly - Future of the Web
CodeValue
 
WebAssembly Overview
Alexandr Skachkov
 
Teaching Machine Learning with Physical Computing - July 2023
Hal Speed
 
An Introduction to WebAssembly
Daniel Budden
 
Hacking ansible
bcoca
 

What's hot (20)

PDF
How WebAssembly is changing the Web and what it means for Angular
Boyan Mihaylov
 
PDF
Why rust?
Mats Kindahl
 
PDF
Big picture of category theory in scala with deep dive into contravariant and...
Piotr Paradziński
 
PDF
Web application architecture guide how it works types, components, best pract...
Katy Slemon
 
PDF
Bootstrap 5 basic
Jubair Ahmed Junjun
 
PDF
Meetup React Sanca - 29/11/18 - React Testing
Augusto Lazaro
 
PDF
Grails 3.0先取り!? Spring Boot入門ハンズオン #jggug_boot
Toshiaki Maki
 
PPTX
Introduction to Spring Framework
Dineesha Suraweera
 
PPTX
Intro to React
Eric Westfall
 
PPTX
RICH INTERNET APPLICATIONS - RIA Tools
Meghana Chandrashekar
 
PDF
AWS Black Belt Online Seminar 2016 AWS上でのActive Directory構築
Amazon Web Services Japan
 
PPTX
Html and css
Samiksha Pun
 
PPTX
Introduction to Node js
Akshay Mathur
 
PPTX
Web assembly: a brief overview
Pavlo Iatsiuk
 
PPTX
Bootstrap 5 whats new
Sandun Perera
 
PDF
Serial Killer - Silently Pwning your Java Endpoints // OWASP BeNeLux Day 2016
Christian Schneider
 
PPTX
Bootstrap 5 ppt
Mallikarjuna G D
 
PPT
Une (simple) présentation de Apache Maven 2
teejug
 
PPTX
Node.JS error handling best practices
Yoni Goldberg
 
How WebAssembly is changing the Web and what it means for Angular
Boyan Mihaylov
 
Why rust?
Mats Kindahl
 
Big picture of category theory in scala with deep dive into contravariant and...
Piotr Paradziński
 
Web application architecture guide how it works types, components, best pract...
Katy Slemon
 
Bootstrap 5 basic
Jubair Ahmed Junjun
 
Meetup React Sanca - 29/11/18 - React Testing
Augusto Lazaro
 
Grails 3.0先取り!? Spring Boot入門ハンズオン #jggug_boot
Toshiaki Maki
 
Introduction to Spring Framework
Dineesha Suraweera
 
Intro to React
Eric Westfall
 
RICH INTERNET APPLICATIONS - RIA Tools
Meghana Chandrashekar
 
AWS Black Belt Online Seminar 2016 AWS上でのActive Directory構築
Amazon Web Services Japan
 
Html and css
Samiksha Pun
 
Introduction to Node js
Akshay Mathur
 
Web assembly: a brief overview
Pavlo Iatsiuk
 
Bootstrap 5 whats new
Sandun Perera
 
Serial Killer - Silently Pwning your Java Endpoints // OWASP BeNeLux Day 2016
Christian Schneider
 
Bootstrap 5 ppt
Mallikarjuna G D
 
Une (simple) présentation de Apache Maven 2
teejug
 
Node.JS error handling best practices
Yoni Goldberg
 
Ad

Similar to Introduction to webassembly (20)

PDF
WebAssemlby vs JavaScript
Alexandr Skachkov
 
PPTX
WebAssembly overview. KievJS meetup
Alexandr Skachkov
 
PPTX
JS Fest 2018. Александр Скачков. WebAssembly vs JavaScript
JSFestUA
 
PPTX
Web Assembly Big Picture
Yousif Shalaby
 
PPT
Web assembly overview by Mikhail Sorokovsky
Valeriia Maliarenko
 
PDF
WebAssembly - kolejny buzzword, czy (r)ewolucja?
Brainhub
 
PDF
Web (dis)assembly
Shakacon
 
PPTX
The Rise of WebAssembly Transforming Web Development for the Modern Era.pptx
SoftflixIT
 
PPTX
WebAssembly WASM Introduction Presentation
Brad Beiermann
 
PPTX
Quick overview of WebAssembly
Karl Ritchie
 
PPTX
Blazor v1.1
Juan Luis Guerrero Minero
 
PDF
WebAssembly - The Journey (BrazilJS 2017 talk)
Elia Maino
 
PDF
WebAssembly vs JavaScript: What is faster?
Alexandr Skachkov
 
PDF
Oleksandr Skachkov - WebAssembly vs JavaScript: What is faster?
OdessaJS Conf
 
PPTX
WebAssembly
Jawahar
 
PDF
WebAssembly with Rust
Knoldus Inc.
 
PDF
Boyan Mihaylov - Is web assembly the killer of javascript
Codemotion
 
PDF
Past, present, and future of web assembly - Devfest Nantes 2017
Alexandre Morgaut
 
PDF
Assembly thy Web
Martin Ockajak
 
PDF
First Step towards WebAssembly with Rust
Knoldus Inc.
 
WebAssemlby vs JavaScript
Alexandr Skachkov
 
WebAssembly overview. KievJS meetup
Alexandr Skachkov
 
JS Fest 2018. Александр Скачков. WebAssembly vs JavaScript
JSFestUA
 
Web Assembly Big Picture
Yousif Shalaby
 
Web assembly overview by Mikhail Sorokovsky
Valeriia Maliarenko
 
WebAssembly - kolejny buzzword, czy (r)ewolucja?
Brainhub
 
Web (dis)assembly
Shakacon
 
The Rise of WebAssembly Transforming Web Development for the Modern Era.pptx
SoftflixIT
 
WebAssembly WASM Introduction Presentation
Brad Beiermann
 
Quick overview of WebAssembly
Karl Ritchie
 
WebAssembly - The Journey (BrazilJS 2017 talk)
Elia Maino
 
WebAssembly vs JavaScript: What is faster?
Alexandr Skachkov
 
Oleksandr Skachkov - WebAssembly vs JavaScript: What is faster?
OdessaJS Conf
 
WebAssembly
Jawahar
 
WebAssembly with Rust
Knoldus Inc.
 
Boyan Mihaylov - Is web assembly the killer of javascript
Codemotion
 
Past, present, and future of web assembly - Devfest Nantes 2017
Alexandre Morgaut
 
Assembly thy Web
Martin Ockajak
 
First Step towards WebAssembly with Rust
Knoldus Inc.
 
Ad

Recently uploaded (20)

PDF
Slides: PDF Eco Economic Epochs for World Game (s) pdf
Steven McGee
 
PDF
DNSSEC Made Easy, presented at PHNOG 2025
APNIC
 
PPTX
dns domain name system history work.pptx
MUHAMMADKAVISHSHABAN
 
PPTX
Different Generation Of Computers .pptx
divcoder9507
 
PPTX
The Monk and the Sadhurr and the story of how
BeshoyGirgis2
 
PPTX
Artificial-Intelligence-in-Daily-Life (2).pptx
nidhigoswami335
 
PDF
Project English Paja Jara Alejandro.jpdf
AlejandroAlonsoPajaJ
 
PPTX
B2B_Ecommerce_Internship_Simranpreet.pptx
LipakshiJindal
 
PPTX
原版北不列颠哥伦比亚大学毕业证文凭UNBC成绩单2025年新版在线制作学位证书
e7nw4o4
 
PPTX
LESSON-2-Roles-of-ICT-in-Teaching-for-learning_123922 (1).pptx
renavieramopiquero
 
PDF
APNIC Update, presented at PHNOG 2025 by Shane Hermoso
APNIC
 
PDF
UI/UX Developer Guide: Tools, Trends, and Tips for 2025
Penguin peak
 
PPTX
Slides Powerpoint: Eco Economic Epochs.pptx
Steven McGee
 
PPTX
Crypto Recovery California Services.pptx
lionsgate network
 
PDF
Cybersecurity Awareness Presentation ppt.
banodhaharshita
 
PDF
Latest Scam Shocking the USA in 2025.pdf
onlinescamreport4
 
PPTX
Black Yellow Modern Minimalist Elegant Presentation.pptx
nothisispatrickduhh
 
PPTX
The Internet of Things (IoT) refers to a vast network of interconnected devic...
chethana8182
 
PDF
PDF document: World Game (s) Great Redesign.pdf
Steven McGee
 
PPTX
Parallel & Concurrent ...
yashpavasiya892
 
Slides: PDF Eco Economic Epochs for World Game (s) pdf
Steven McGee
 
DNSSEC Made Easy, presented at PHNOG 2025
APNIC
 
dns domain name system history work.pptx
MUHAMMADKAVISHSHABAN
 
Different Generation Of Computers .pptx
divcoder9507
 
The Monk and the Sadhurr and the story of how
BeshoyGirgis2
 
Artificial-Intelligence-in-Daily-Life (2).pptx
nidhigoswami335
 
Project English Paja Jara Alejandro.jpdf
AlejandroAlonsoPajaJ
 
B2B_Ecommerce_Internship_Simranpreet.pptx
LipakshiJindal
 
原版北不列颠哥伦比亚大学毕业证文凭UNBC成绩单2025年新版在线制作学位证书
e7nw4o4
 
LESSON-2-Roles-of-ICT-in-Teaching-for-learning_123922 (1).pptx
renavieramopiquero
 
APNIC Update, presented at PHNOG 2025 by Shane Hermoso
APNIC
 
UI/UX Developer Guide: Tools, Trends, and Tips for 2025
Penguin peak
 
Slides Powerpoint: Eco Economic Epochs.pptx
Steven McGee
 
Crypto Recovery California Services.pptx
lionsgate network
 
Cybersecurity Awareness Presentation ppt.
banodhaharshita
 
Latest Scam Shocking the USA in 2025.pdf
onlinescamreport4
 
Black Yellow Modern Minimalist Elegant Presentation.pptx
nothisispatrickduhh
 
The Internet of Things (IoT) refers to a vast network of interconnected devic...
chethana8182
 
PDF document: World Game (s) Great Redesign.pdf
Steven McGee
 
Parallel & Concurrent ...
yashpavasiya892
 

Introduction to webassembly