hyperapp VS Snowpack

Compare hyperapp vs Snowpack and see what are their differences.

hyperapp

1kB-ish JavaScript framework for building hypertext applications (by jorgebucaran)

Snowpack

ESM-powered frontend build tool. Instant, lightweight, unbundled development. ✌️ [Moved to: https://github.com/FredKSchott/snowpack] (by withastro)
Our great sponsors
  • SurveyJS - Open-Source JSON Form Builder to Create Dynamic Forms Right in Your App
  • WorkOS - The modern identity platform for B2B SaaS
  • InfluxDB - Power Real-Time Data Analytics at Scale
hyperapp Snowpack
18 69
19,024 19,787
- -
2.9 8.4
3 months ago about 2 years ago
JavaScript JavaScript
MIT License MIT License
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

hyperapp

Posts with mentions or reviews of hyperapp. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-05-25.
  • VanJS (Vanilla JavaScript): smallest reactive UI framework
    21 projects | news.ycombinator.com | 25 May 2023
    Please check out https://github.com/jorgebucaran/hyperapp
  • Show HN: Dak – a Lisp like language that transpiles to JavaScript
    6 projects | news.ycombinator.com | 27 Feb 2023
  • Espresso.js – minimal React alternative – is now a decade old
    5 projects | news.ycombinator.com | 5 Oct 2022
    The likely reason it never caught on, is that it has similar pitfalls as Backbone:

    - manually attaching DOM elements to view controllers

    - manually attaching child views

    - models which have to be wired individually via .listenTo

    - possibility of infinite loops if the events accidentally recurse

    A better tiny alternative would be hyperapp[1] or even Preact, that has a similar bundle size.

    [1] https://github.com/jorgebucaran/hyperapp

  • How hard is it to get a Mid FE position without any commercial framework experience?
    2 projects | /r/Frontend | 23 Sep 2022
    If they're focused on performance and bundle size, it's your chance to try some minimalistic exotic stuff like hyperapp (https://github.com/jorgebucaran/hyperapp) or mithril (https://mithril.js.org/) Just for fun
  • AlpineJS
    2 projects | dev.to | 10 Sep 2022
    With a bit of a deadline (due to a mixture of procrastination and confidence that Vue would work) I needed something quick. I have also used Hyperapp in the past but that looks like a dead project right now (although arguably it has all the functionality you need so why keep developing it?).
  • What I learned working with a senior engineer as a new grad
    3 projects | news.ycombinator.com | 19 Aug 2022
    I’m glad it left that impression! My thoughts have clarified a bit since I read that post, and I think what I describe is more declarative, like React. But the best places to read about it (for web devs) are in Elm!

    There is also this new thing I found that seems to really lean into the core of what being functional means here: https://github.com/jorgebucaran/hyperapp

    After a while, you see that basically all systems can be modeled as event-driven, functional systems. It’s a flexible model, and fits beautiful into web dev where the semantics are very clear: the system is the web app and events are clicks, keyboard events, asynchronous calls...

  • Best JS library/bundler combo for ABSOLUTE MINIMUM production build size possible
    2 projects | /r/Frontend | 26 Jun 2022
    Hyperapp is 1kb.
  • What's your favorite frontend framework?
    2 projects | /r/webdev | 12 May 2022
    - Hyperapp (https://github.com/jorgebucaran/hyperapp) - Preact - Svelte - React / Vue
  • Divergent States in a "Single Source of Truth" Framework
    1 project | dev.to | 7 Apr 2022
    I'll tell you what I've learnt from struggling with a bug that made me lose a couple of weeks. The application framework used in this post is Hyperapp, but I guess the same problem can be found in frameworks based on transforming the state of "Single Source of Truth" with pure functions (such as Elm, Redux, so on) if we use them in a wrong way.
  • Popular 'coa' NPM library hijacked to steal user passwords
    3 projects | /r/javascript | 5 Nov 2021
    Personally, I try my best to avoid bringing in dependencies as much as possible, and try to limit my exposure to only dependencies with low/shallow transitive dependency counts. Unfortunately, this is pretty hard, especially in corporate settings. What we need more of are the opposite of what we've been collectively praising: we need more monolithic packages. Case in point: lodash.template is currently vulnerable with no mitigation, even though lodash itself is not. That's just sloppy publishing practices. Esbuild is a great start over the webpack/babel maze of dependencies. There's a stdlib effort along those lines that hopefully would also help. There's a bunch of micro-frameworks that are used in production just fine and have little to no dependencies.

Snowpack

Posts with mentions or reviews of Snowpack. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2022-03-25.
  • How to replace webpack & babel with Vite on a legacy React Typescript project
    11 projects | dev.to | 25 Mar 2022
    Then there was Webpack which seemed like it would be around for a while. Even after things like Parcel and Snowpack came on the scene people still recommended Webpack. I mean, it's still the backbone of create-react-app. An then, Vite was released.
  • State of the Web: Bundlers & Build Tools
    17 projects | dev.to | 23 Jan 2022
    Unbundled development utilizes native ESM support in browsers to offer an ultra-fast development experience. Unlike a traditional bundler which bundles everything in development, unbundled development transforms the code and rewrites import paths to the ESM compliant file path without bundling your code. Additionally, most bundlers that do this pre-bundle dependencies because that decreases the number of imports needed, and dependencies are unlikely to change often. The two most prominent bundlers that utilize unbundled development are Vite and Snowpack. Snowpack, created in 2019, was the first bundler to have an unbundled development experience. However, while Snowpack was popular for some time, this did not last forever. In 2020, the team behind Vue created Vite. Vite has many advantages over Snowpack, like the ease of use, speed, better optimization, and more. Additionally, popular projects like SvelteKit adopted Vite instead of Snowpack. All of this helped Vite pass Snowpack in downloads, and it now has more than 10x downloads compared to Snowpack. In fact, even Astro, a project created by the team behind Snowpack (be on the lookout for an article about Astro), is now using Vite. Overall, if you want fast, unbundled development, I recommend Vite.
  • What are the new and exciting tech for React projects for 2022?
    16 projects | /r/reactjs | 5 Jan 2022
    I've been hearing good things about snowpack and have been wanting to give it a go myself as an alternative to webpack/babel
  • Converting to Vite (Part 1)
    4 projects | dev.to | 5 Jan 2022
    So how did we get here? Well, it's a good thing to describe alternatives considered when you add issues to a repo! Months ago, @0vortex described in Issue #1131 some opportunities for dependency updates that would require version 5 of webpack with our webpack configuration, and warned that the dependency management would probably be tricky. I fixated on an alternative that he mentioned about converting the project to use Snowpack. I had wanted to learn more about bundling tools, so I took a few days here and there after Thanksgiving and got Open Sauced mostly working with it (see PR #1320).
  • npx create-react-app not working -- everything is deprecated
    5 projects | /r/react | 11 Dec 2021
  • React 101: The Basics
    12 projects | dev.to | 30 Nov 2021
    I have written a post about setting up a React project using Parcel as a bundler which can give a more detailed walkthrough about getting a React application up and running from scratch. There are multiple ways to do this but some of the more common build tools include Webpack, Parcel, and Snowpack.
  • SolidJS on Snowpack – Quick Dev Guide
    2 projects | dev.to | 17 Nov 2021
    For more information about this issue, check these issue tickets: Issue 2998, Issue 3219, Issue 3243
  • Etsy’s Journey to TypeScript
    6 projects | news.ycombinator.com | 16 Nov 2021
    The number of transforms that Babel is doing with an "evergreen" config ("last 2 browser versions") at this point is effectively miniscule. It's a massive toolchain for what increasing turns out to be a minimal amount of actual work. "Last 2 Browser Versions" is effectively everything through ES2019 at this point which covers almost all of the "modern JS syntax". If you aren't using custom transforms you might not be transforming anything that matters in Babel in 2021. I've seen a bunch of projects with huge Babel pipelines where the only actual transform was Typescript's type removal and at that point, if your codebase is entirely Typescript, Typescript has all the downlevel transforms you need "baked in" (and arguably a little bit cleaner and simpler to Babel's kitchen sink but also still somehow millions of plugins approach) and it's just setting Typescript's compile option to the ES level you are most comfortable with. (In 2021 that may even be as high as { "target": "es2019" } or higher in your tsconfig.json and even there Typescript's not going to even need to downlevel much.) Typescript can also transform TSX/JSX to JS without the need of Babel, if you are using React.

    Even ES2015 modules which some people still think is the big reason to keep Babel around: a) has full Browser support if you use type="module", but most people still want to pack their JS because just about no one is assuming HTTP/2 or HTTP/3 yet, and b) Babel has never done module format transforms, that's always been the domain of your packer (webpack, parcel, rollup, snowpack, what have you).

    If you are updating your project stack in 2021 right now my personal top recommendation is that I really like the approach of snowpack (https://www.snowpack.dev/): ES2105 modules with dev experience (which is great), great Typescript support, and a simpler overall config experience than most other options right now. (It uses esbuild under the hood rather than babel for dev and basic transforms/bundling. It can optionally piggy back webpack and parcel for Production bundling that needs more "power".) Especially that <script type='module"> dev experience feels great now (with Hot Module Reloading too) versus waiting for a full bundle even for dev builds.

  • Build your own component library with Svelte
    10 projects | dev.to | 9 Nov 2021
    SvelteKit uses Vite under the hood, which is quite surprising, as Sapper and most tools are developed using Snowpack. Vite 2 is framework-agnostic and designed with SSR at its core.
  • Angular Is Rotten to the Core
    9 projects | news.ycombinator.com | 4 Nov 2021
    I've had some success with npm, snowpack, mocha, typescript as that sort of stack for more "vanilla" efforts that feel rather more "modern". I think mocha is easier and cleaner than jest. I like keeping all of my transpilation to just Typescript without needing a massive Babel install/pipeline. snowpack (https://www.snowpack.dev/) right now I think is in a sweet spot of a better "ES Module native" developer experience than webpack and has better defaults when left unconfigured. (So much so that while there are snowpack templates/generators provided by the project I mostly don't use them other than for reference.)

What are some alternatives?

When comparing hyperapp and Snowpack you can also consider the following projects:

Preact - ⚛️ Fast 3kB React alternative with the same modern API. Components & Virtual DOM.

vite - Next generation frontend tooling. It's fast!

tape - tap-producing test harness for node and browsers

Rollup - Next-generation ES module bundler

DalekJS - [unmaintained] DalekJS Base framework

parcel - The zero configuration build tool for the web. 📦🚀

riot - Simple and elegant component-based UI library

esbuild - An extremely fast bundler for the web

solid - A declarative, efficient, and flexible JavaScript library for building user interfaces. [Moved to: https://github.com/solidui/solid]

gulp - A toolkit to automate & enhance your workflow

Alpine.js - A rugged, minimal framework for composing JavaScript behavior in your markup.

webpack - A bundler for javascript and friends. Packs many modules into a few bundled assets. Code Splitting allows for loading parts of the application on demand. Through "loaders", modules can be CommonJs, AMD, ES6 modules, CSS, Images, JSON, Coffeescript, LESS, ... and your custom stuff.