Skip to content

Latest commit

 

History

History
90 lines (65 loc) · 2.28 KB

README.md

File metadata and controls

90 lines (65 loc) · 2.28 KB
Hyperactive

hyperactive

Hyperactive is a powerful set of tools to build reactive web applications.

We're currently working on a 2.0 release, which will include fully reactive client-side rendering. To try the latest version, you can get hyper:

npm install https://gethyper.dev

yarn add https://gethyper.dev

pnpm add https://gethyper.dev

bun install https://gethyper.dev

Hyperactive is also available on NPM.

This is not a release version, so expect some bugs.

Hyperactive Version 2.0.0-beta.1

Usage

On the server

import { renderHTML } from "@hyperactive/hyper";
import { div, p, h1, br } from "@hyperactive/hyper/elements";

assertEquals(
  renderHTML(
    section(
      { class: "container" },
      div(
        img({ src: "/hero.jpg" }),
        h1("Hello World"),
      ),
    ),
  ),
  `<div class="container"><div><img src="/hero.jpg" /><h1>Hello World</h1></div></div>`,
);

In the browser

@types/web 0.0.188

Please install @types/web to use Hyperactive in the browser. Your package manager will automatically install the correct version of @types/web for you by default. See the versions table for the correct version of @types/web for each version of Hyperactive.

bun install @types/web
import { State, renderDOM } from "@hyperactive/hyper";
import { div, p, button } from "@hyperactive/hyper/elements";

const s = new State(0);

const root = document.getElementById("root");

renderDOM(
  root,
  div(
    p("You clicked ", s, " times"),
    button(
      { on: { click: () => s.update(s.value + 1) } },
      "Increment"
    ),
  ),
);

Testimonials

Thomas's testimonial