hyper(HTML)
A Fast & Light Virtual DOM Alternative available for Node.js and NativeScript too.
hypersimple
If you've just started with template literals based projects and you like components, or you'd like to understand what's hyperHTML capable of, give hypersimple a try 🎉
lighterhtml 💡
This little brother is "showing off" these days, claiming better performance and unprecedented ease of use.
GitHub Repository
Neverland 🌈🦄
If you like React hooks concept, don't miss this little wrap that adds 0.something overhead to the already lightweight hyperHTML, bringing in very similar concepts.
Blog Post
GitHub Repository
Haunted 🦇 🎃
If you also like React hooks mechanism and you'd like to combine these via hyperHTML or HyperHTMLElement, try haunted out!
Bundlers
You can require or import hyperHTML with any bundler and in different ways.
If requiring or importing from "hyperhtml"
doesn't work, try requiring from "hyperhtml/cjs"
for CommonJS friendly bundlers (WebPack), or "hyperhtml/esm"
for ESM compatible bundlers (Rollup).
See HELPERS.md for a list of additional tools which can be helpful for building hyperHTML based web applications.
Support this project by becoming a sponsor. Your logo will show up here with a link to your website. [Become a sponsor]
Backers
Thank you to all our backers! 🙏 [Become a backer]
Contributors
This project exists thanks to all the people who contribute. [Contribute].
Seamlessly Isomorphic
No matter if you use ESM or CommonJS, you can use hypermorphic
to load same features on both client and server.
import {bind, wire} from 'hypermorphic';
const {bind, wire} = require('hypermorphic');
V2.5 Highlights
<self-closing />
tags for both custom elements and any other as well 🎉
V2 Highlights
Following most important changes in version 2:
- fully rewritten, and consumable, as ES2015 Module
- usable via CDN as bundled global
hyperHTML
variable - restructured in modules, utilities, helpers, and commented all over for simplified contribution
- removed
.escape
and .adopt
, either useless or unstable. hyperHTML.adopt
will be implemented as module a part - added support for objects as
style
attribute, fully compatible with Preact implementation - improved performance in numerous ways
- custom elements V0 and V1 are now fully, and properly, supported through
document.importNode
and/or regular cloneNode
tested against common polyfills - back to 4.6K thanks to rollup and its ability to merge all the things together like it was already in V1
Documentation
A proper documentation full of examples can be found in viperhtml.js.org.
Basic Example
The easiest way to describe hyperHTML
is through an example.
function tick(render) {
render`
<div>
<h1>Hello, world!</h1>
<h2>It is ${new Date().toLocaleTimeString()}.</h2>
</div>
`;
}
setInterval(tick, 1000,
hyperHTML(document.getElementById('root'))
);
Features
- Zero dependencies, no polyfills needed, and it fits in about 4.6KB (minified + brotli)
- Uses directly native DOM, no virtual DOM involved
- Designed for template literals, a templating feature built in to JS
- Compatible with plain DOM elements and plain JS data structures
- Also compatible with Babel transpiled output, hence suitable for every browser you can think of
Compatibility
IE9+ , iOS8+ , Android 4+ and every modern Mobile or Desktop Browser.
You can verify directly through the following links:
Weakmap error on ie < 11
'@ungap/weakmap': object is not extensible
Babel freezes the template literals by spec but that causes problems with the weakmap polyfill. To fix this error add the fix explained on ungap/weakmap
HTML Syntax Highlight
If you are using Visual Studio Code you can install literally-html
to highlight all literals handled by hyperHTML
and others.
Prettier Templates
If you'd like to make your templates prettier than usual, don't miss this plugin: https://github.com/sgtpep/prettier-plugin-html-template-literals
Questions ?
Please ask anything you'd like to know in StackOverflow using the tag hyperhtml
so that others can benefit from answers and examples.
hyper or lit ?
You can read more on this hyperHTML vs lit-html comparison.
installation?
npm install hyperhtml
If your bundler does not work with the following:
import hyperHTML from 'hyperhtml';
const hyperHTML = require('hyperhtml');
You can try any of these other options.
import hyperHTML from 'hyperhtml/esm';
import {hyper, wire, bind, Component} from 'hyperhtml/esm';
import hyperHTML from 'https://unpkg.com/hyperhtml?module';
const hyperHTML = require('hyperhtml/cjs').default;
const {hyper, wire, bind, Component} = require('hyperhtml/cjs');
In alternative, there is a pre-bundled require("hyperhtml/umd")
or via unpkg as UMD module.