Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Free Learning
Arrow right icon
Arrow up icon
GO TO TOP
Creative DIY Microcontroller Projects with TinyGo and WebAssembly

You're reading from   Creative DIY Microcontroller Projects with TinyGo and WebAssembly A practical guide to building embedded applications for low-powered devices, IoT, and home automation

Arrow left icon
Product type Paperback
Published in May 2021
Publisher Packt
ISBN-13 9781800560208
Length 322 pages
Edition 1st Edition
Languages
Tools
Arrow right icon
Author (1):
Arrow left icon
Tobias Theel Tobias Theel
Author Profile Icon Tobias Theel
Tobias Theel
Arrow right icon
View More author details
Toc

Table of Contents (13) Chapters Close

Preface 1. Chapter 1: Getting Started with TinyGo 2. Chapter 2: Building a Traffic Lights Control System FREE CHAPTER 3. Chapter 3: Building a Safety Lock Using a Keypad 4. Chapter 4: Building a Plant Watering System 5. Chapter 5: Building a Touchless Handwash Timer 6. Chapter 6: Building Displays for Communication using I2C and SPI Interfaces 7. Chapter 7: Displaying Weather Alerts on the TinyGo Wasm Dashboard 8. Chapter 8: Automating and Monitoring Your Home through the TinyGo Wasm Dashboard 9. Assessments 10. Afterword 11. Other Books You May Enjoy Appendix – "Go"ing Ahead

Displaying sensor data and weather alerts on a Wasm page

Our goal is to develop a small application that displays weather alerts and our sensor data that is being published to an MQTT broker, so we will need some very basic HTML and JavaScript skills in order to achieve this. We start by developing a small server that serves the Wasm app to a client.

Serving the application

As Wasm is served to a browser, we need an HTTP endpoint that serves all files we might need. We start by creating a new folder named wasm-server inside the Chapter07 folder, and inside this folder we create a new main.go file with an empty main function. Now, follow these steps to implement the server:

  1. Define the directory where the FileServer should look for files, as follows:
    const dir = "Chapter07/html"
  2. Now, inside the main function, create a new FileServer and pass the directory as a parameter, as follows:
    fs := http.FileServer(http.Dir(dir))
  3. Start an HTTP server that listens...
lock icon The rest of the chapter is locked
Register for a free Packt account to unlock a world of extra content!
A free Packt account unlocks extra newsletters, articles, discounted offers, and much more. Start advancing your knowledge today.
Unlock this book and the full library FREE for 7 days
Get unlimited access to 7000+ expert-authored eBooks and videos courses covering every tech area you can think of
Renews at $19.99/month. Cancel anytime
Banner background image