Logo

dev-resources.site

for different kinds of informations.

Exploring Frontend Technologies: Elm vs. Svelte

Published at
6/29/2024
Categories
elm
svelte
webdev
hng
Author
0mobolaji
Categories
4 categories in total
elm
open
svelte
open
webdev
open
hng
open
Author
9 person written this
0mobolaji
open
Exploring Frontend Technologies: Elm vs. Svelte

I recently joined HNG internship, it's a fast paced, online bootcamp for coders from various backgrounds including frontend, backend, data analysis, and product design. They also have a marketplace for hiring top talentโ€”learn more here. Our first task was to write a technical article comparing two front-end technologies. I initially considered writing about ReactJS, the language we'll use in the bootcamp, but there are already tons of articles about ReactJS. So I decided to write about something less common: Elm, and since I'm to compare with another technology, I'm going with Svelte.

Let's start with Elm

Elm is a functional programming language specifically designed for front-end development. Created by Evan Czaplicki, Elm compiles to JavaScript and emphasizes immutability and type safety, ensuring robust and maintainable codebases.

Elm is ideal for projects where reliability and maintainability are paramount. Its strong typing and functional programming paradigm make it suitable for large-scale applications that require rigorous code quality and robustness.

One distinguishing feature of Elm that makes it so different is, all functions written in Elm cannot cause side effects, they are mandatorily pure. But that doesn't mean you cannot develop dynamic pages with it because even if all the functions are pure, there is still a runtime capable of performing some type of side effects, which includes triggering REST services. This one feature makes development much more predictable and easy to maintain.

Another feature I really loved was no runtime errors. Yes, that's right. It's almost impossible to generate unexpected failure while running your applications. Unlike JavaScript that, no matter how hard you try, errors will always find a way to pop it's ugly head up, that doesn't happen in Elm. The compiler will always show where and how an error can occur and force you to deal with it! Like a friend said, "It's like programming with someone helping you all the time not to screw up!".

And if you're new to the functional programming world, Elm's compiler generate very friendly error messages that not only point out the mistakes but also teaches the syntax of the language. How cool is that?

Another cool feature to note is it's package management. Elm enforces semantic versioning and it's possible to compare what has changes from one version of a package to another, using the command elm diff followed by the name and the versions you want to compare.

You can learn more about this beautiful language here

Now, to Svelte

Svelte, created by Rich Harris, is a relatively new framework that shifts much of the work from the browser to the build step, producing highly optimized vanilla JavaScript. Unlike traditional frameworks like React or Vue, which use a virtual DOM, Svelte compiles components to efficient imperative code that directly updates the DOM.

Key Features

  • No Virtual DOM: Svelte components compile to highly optimized JavaScript that directly manipulates the DOM, resulting in faster updates and smaller bundle sizes.

  • Reactive Declarations: Svelte's reactivity is built into the language, allowing for concise and clear state management without the need for additional libraries.

  • Lightweight Runtime: Applications built with Svelte often have smaller initial loads and faster runtime performance compared to other frameworks.

Use Cases

Svelte is particularly well-suited for projects where performance and bundle size are critical. Its simplicity and lack of boilerplate code make it an excellent choice for smaller projects or teams looking to quickly prototype and develop applications.

Bootcamp Opportunity

If you'll like to join me in the HNG internship bootcamp, register here. They also offer a certification upon completion for a small fee. This internship is a fantastic opportunity to apply your knowledge, learn from experienced developers, and contribute to real-world projects. Don't miss out!

Conclusion

Svelte and Elm offer unique approaches to frontend development, each with its own strengths and ideal use cases. Svelte focuses on simplicity and performance, while Elm emphasizes reliability through functional programming.

elm Article's
30 articles in total
Favicon
10 Months of Elm to Angular
Favicon
25 Must-Check Elm Resources for Developers: Tutorials, Tools, and Tips
Favicon
๐Ÿƒ 30 Elm Picks to Fuel Your Functional Code
Favicon
Stateless and stateful components. No! Reusable views in Elm.
Favicon
On why I prefer not to use elm-css
Favicon
GitHub Actions, Devbox, and Elm
Favicon
Run Elm and lunarvim in a devcontainer
Favicon
How to host Browser.application projects
Favicon
How I host Elm web applications with GitHub Pages
Favicon
Announcing my newsletter "Elm with Dwayne"
Favicon
Using ChatGPT o1 to write UI code with Elm
Favicon
Exploring Svelte and Elm: A Comparative Look at Unique Frontend Technologies
Favicon
Exploring Frontend Technologies: Elm vs. Svelte
Favicon
Using a continuation-passing interpreter to make an interactive read operation for the browser with Elm
Favicon
How I use Devbox in my Elm projects
Favicon
Yet Another Tour of an Open-Source Elm SPA
Favicon
Elm 2023, a year in review
Favicon
For lack of a better name, Iโ€™m calling it โ€œThe Module Patternโ€.
Favicon
Exploring the Elm Architecture for Web Applications
Favicon
How to use Elm extensible records
Favicon
Elm with flex and color
Favicon
How I use Nix in my Elm projects
Favicon
Record Type Alias Combinators: A Public Service Announcement
Favicon
Parsing AWS AppSync Responses, Elm GraphQL Libraries, and Only Doing Front-End
Favicon
On continuation-passing style and the factorial function
Favicon
Announcing elm-integer
Favicon
Stricter TypeScript >, <, and ===
Favicon
Final Fantasy Legend Level Editor Update
Favicon
Rebuilding Final Fantasy Legend in Elm
Favicon
Building mobile apps using Elm and Capacitor

Featured ones: