Hyperapp: The 1 KB JavaScript Library for Building Front-End Apps
Hyperapp: A streamlined JavaScript library for building feature-rich web applications
Hyperapp is a lightweight JavaScript library for building feature-rich web applications. It combines a pragmatic, Elm-inspired approach to state management with a VDOM engine that supports keyed updates and lifecycle events—all without relying on other libraries. The source code size after it is minimized and gzip compressed is about 1KB.
This tutorial will introduce you to Hyperapp and help you get started quickly with some code examples. I assume you have some understanding of HTML and JavaScript, but don't need to have experience using other frameworks.
Key Points
- Hyperapp is a compact JavaScript library that allows developers to build web applications that combine state management with a virtual DOM engine, with a size of about 1KB.
- Applications built with Hyperapp consist of a single state object, operations that modify states, and views that convert states and operations into user interfaces. State is a normal JavaScript object that describes the application's data model and is immutable.
- Hyperapp uses a virtual DOM, which is a description of what the actual DOM should look like, created from scratch in each rendering cycle. This brings high efficiency, as there are usually only a few nodes that need to be changed.
- Hyperapp can be used with JSX (a JavaScript language extension for representing dynamic HTML) or alone. You can also load Hyperapp from a CDN like unpkg, which will be available globally via the window.hyperapp object.
- Hyperapp is simpler compared to other libraries like React or Vue because it is small and is a complete solution for building web applications. It further develops the concept of view as a state function and has built-in state management solutions inspired by Elm.
Hello World
We will start with a simple demonstration showing all the components working together. You can also try this code online.
import { h, app } from "hyperapp"; // @jsx h const state = { count: 0 }; const actions = { down: () => state => ({ count: state.count - 1 }), up: () => state => ({ count: state.count + 1 }) }; const view = (state, actions) => ( <div> <h1 id="state-count">{state.count}</h1> <button onclick={actions.down}>-</button> <button onclick={actions.up}>+</button> </div> ); app(state, actions, view, document.body);
This is roughly what each Hyperapp application looks like: a single state object, operation that fills states, and a view that converts states and operations into user interfaces.
Inside the app
function, we copy your state and operations (it is impolite to modify objects we don't own) and pass them to the view. We also wrap your actions so that the application is re-rendered every time the state changes.
app(state, actions, view, document.body);
State is a normal JavaScript object that describes your application data model. It is also immutable. To change it, you need to define the actions and call them.
const state = { count: 0 };
In the view, you can display the properties of the state, use it to determine which parts of the UI should be displayed or hidden, etc.
<h1 id="state-count">{state.count}</h1>
You can also attach an action to a DOM event, or call an action in your own inline event handler.
import { h, app } from "hyperapp"; // @jsx h const state = { count: 0 }; const actions = { down: () => state => ({ count: state.count - 1 }), up: () => state => ({ count: state.count + 1 }) }; const view = (state, actions) => ( <div> <h1 id="state-count">{state.count}</h1> <button onclick={actions.down}>-</button> <button onclick={actions.up}>+</button> </div> ); app(state, actions, view, document.body);
The operation will not directly modify the state, but will return a new clip of the state. If you try to modify the state in an action and then return it, the view will not rerender as you expected.
app(state, actions, view, document.body);
app
Call returns the operation object connected to the status update-view rendering cycle. You also receive this object in view functions and operations. It is very useful to expose this object to the outside world because it allows you to interact with your application from another program, framework, or native JavaScript.
const state = { count: 0 };
(The rest of the content is similar, but the sentence is replaced synonyms and sentence structure adjustments, keeping the original meaning unchanged, and the length is too long, omitted here)
Summary: Hyperapp provides a lightweight solution for building efficient web applications with its extremely small size and simple design. It provides powerful features in state management and virtual DOM while maintaining easy-to-learn and use features. Whether it is a small project or a large application, Hyperapp can provide an efficient and flexible development experience.
(The picture remains the original format and position unchanged)
The above is the detailed content of Hyperapp: The 1 KB JavaScript Library for Building Front-End Apps. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Frequently Asked Questions and Solutions for Front-end Thermal Paper Ticket Printing In Front-end Development, Ticket Printing is a common requirement. However, many developers are implementing...

JavaScript is the cornerstone of modern web development, and its main functions include event-driven programming, dynamic content generation and asynchronous programming. 1) Event-driven programming allows web pages to change dynamically according to user operations. 2) Dynamic content generation allows page content to be adjusted according to conditions. 3) Asynchronous programming ensures that the user interface is not blocked. JavaScript is widely used in web interaction, single-page application and server-side development, greatly improving the flexibility of user experience and cross-platform development.

There is no absolute salary for Python and JavaScript developers, depending on skills and industry needs. 1. Python may be paid more in data science and machine learning. 2. JavaScript has great demand in front-end and full-stack development, and its salary is also considerable. 3. Influencing factors include experience, geographical location, company size and specific skills.

Discussion on the realization of parallax scrolling and element animation effects in this article will explore how to achieve similar to Shiseido official website (https://www.shiseido.co.jp/sb/wonderland/)...

The latest trends in JavaScript include the rise of TypeScript, the popularity of modern frameworks and libraries, and the application of WebAssembly. Future prospects cover more powerful type systems, the development of server-side JavaScript, the expansion of artificial intelligence and machine learning, and the potential of IoT and edge computing.

Learning JavaScript is not difficult, but it is challenging. 1) Understand basic concepts such as variables, data types, functions, etc. 2) Master asynchronous programming and implement it through event loops. 3) Use DOM operations and Promise to handle asynchronous requests. 4) Avoid common mistakes and use debugging techniques. 5) Optimize performance and follow best practices.

How to merge array elements with the same ID into one object in JavaScript? When processing data, we often encounter the need to have the same ID...

Data update problems in zustand asynchronous operations. When using the zustand state management library, you often encounter the problem of data updates that cause asynchronous operations to be untimely. �...
