0.37.20 • Published 18 days ago

hyper-dom-expressions v0.37.20

Weekly downloads
635
License
MIT
Repository
github
Last release
18 days ago

Hyper DOM Expressions

Build Status NPM Version npm.io npm.io

This package is a Runtime API built for DOM Expressions to provide HyperScript DSL for reactive libraries that do fine grained change detection. While the JSX plugin Babel Plugin JSX DOM Expressions is more optimized with precompilation, smaller size, and cleaner syntax, this HyperScript solution has the flexibility of not being precompiled. However, Tagged Template Literals are likely a better choice in terms of performance in non-compiled environments Lit DOM Expressions.

Compatible Libraries

  • Solid: A declarative JavaScript library for building user interfaces.
  • ko-jsx: Knockout JS with JSX rendering.
  • mobx-jsx: Ever wondered how much more performant MobX is without React? A lot.

Getting Started

Install alongside the DOM Expressions and the fine grained library of your choice. For example with S.js:

> npm install s-js dom-expressions hyper-dom-expressions

Create your configuration and run dom-expressions command to generate runtime.js. More info here.

Use it to initialize your Hyper function

import { createHyperScript } from 'hyper-dom-expressions';
import * as r from './runtime';

const h = createHyperScript(r);

Profit:

const view = h('table.table.table-hover.table-striped.test-data',
  h('tbody', mapSample(() => state.data, row =>
    h('tr', [
      h('td.col-md-1', row.id),
      h('td.col-md-4', h('a', {onClick: [select, row.id]}, () => row.label)),
      h('td.col-md-1', h('a', {onClick: [remove, row.id]}, h('span.glyphicon.glyphicon-remove'))),
      h('td.col-md-6')
    ])
  ))
));

S.root(() => r.insert(document.getElementById('main'), view());)

Libraries may expose access to h in different ways. For example Solid has it's own entry point 'solid-js/h'.

Differences from JSX

There are also several small differences but generally follows HyperScript conventions. Ref work by passing a function. Keep in mind you need to wrap expressions in functions if you want them to be observed. For attributes since wrapping in a function is the only indicator of reactivity, passing a non-event function as a value requires wrapping it in a function.

Fragments are just arrays. Components are handled by passing a Function to the first argument of the h function. Ie:

const view = <>
  <Component prop={value} />
  {someValue()}
</>

// is equivalent to:
const view = [
  h(Component, {prop: value}),
  () => someValue()
]

Status

I'm still working out API details and performance profiling.

0.37.20

18 days ago

0.37.19

2 months ago

0.37.18

2 months ago

0.37.17

3 months ago

0.37.16

4 months ago

0.37.15

4 months ago

0.37.14

4 months ago

0.37.13

4 months ago

0.37.12

4 months ago

0.37.11

4 months ago

0.37.3

7 months ago

0.37.9

6 months ago

0.37.8

7 months ago

0.37.7

7 months ago

0.37.6

7 months ago

0.37.5

7 months ago

0.37.4

7 months ago

0.37.10

5 months ago

0.36.18

8 months ago

0.37.0-beta.4

7 months ago

0.37.2

7 months ago

0.37.0-beta.3

7 months ago

0.37.1

7 months ago

0.37.0-beta.2

7 months ago

0.37.0

7 months ago

0.37.0-beta.1

7 months ago

0.37.0-beta.0

8 months ago

0.36.13

12 months ago

0.36.16

9 months ago

0.36.17

9 months ago

0.36.14

10 months ago

0.36.15

10 months ago

0.36.12

1 year ago

0.36.10

1 year ago

0.36.11

1 year ago

0.36.0-beta.4

1 year ago

0.36.0-beta.5

1 year ago

0.36.0-beta.6

1 year ago

0.36.0-beta.7

1 year ago

0.36.0-beta.8

1 year ago

0.36.0-beta.9

1 year ago

0.36.0-beta.0

1 year ago

0.36.0-beta.1

1 year ago

0.36.0-beta.2

1 year ago

0.36.0-beta.3

1 year ago

0.35.19

1 year ago

0.35.17

1 year ago

0.35.18

1 year ago

0.35.16

1 year ago

0.36.4

1 year ago

0.36.3

1 year ago

0.36.2

1 year ago

0.36.1

1 year ago

0.36.0

1 year ago

0.36.9

1 year ago

0.36.8

1 year ago

0.36.6

1 year ago

0.36.5

1 year ago

0.35.22

1 year ago

0.35.23

1 year ago

0.35.20

1 year ago

0.35.21

1 year ago

0.35.12

1 year ago

0.35.15

1 year ago

0.35.13

1 year ago

0.35.14

1 year ago

0.35.11

1 year ago

0.35.10

1 year ago

0.34.13

2 years ago

0.35.0-beta.4

2 years ago

0.35.0-beta.3

2 years ago

0.35.5

1 year ago

0.35.4

1 year ago

0.35.3

2 years ago

0.35.2

2 years ago

0.35.1

2 years ago

0.35.0

2 years ago

0.35.9

1 year ago

0.35.8

1 year ago

0.35.7

1 year ago

0.35.6

1 year ago

0.35.0-beta.0

2 years ago

0.35.0-beta.2

2 years ago

0.35.0-beta.1

2 years ago

0.34.10

2 years ago

0.34.11

2 years ago

0.34.12

2 years ago

0.34.0-beta.5

2 years ago

0.34.6

2 years ago

0.34.5

2 years ago

0.34.4

2 years ago

0.34.3

2 years ago

0.34.2

2 years ago

0.34.1

2 years ago

0.34.0

2 years ago

0.34.9

2 years ago

0.34.8

2 years ago

0.34.7

2 years ago

0.33.10

2 years ago

0.33.7

2 years ago

0.33.14

2 years ago

0.33.13

2 years ago

0.33.12

2 years ago

0.33.9

2 years ago

0.33.11

2 years ago

0.33.8

2 years ago

0.34.0-beta.1

2 years ago

0.34.0-beta.0

2 years ago

0.34.0-beta.4

2 years ago

0.34.0-beta.3

2 years ago

0.34.0-beta.2

2 years ago

0.33.6

2 years ago

0.33.5

2 years ago

0.33.4

2 years ago

0.33.3

2 years ago

0.33.2

2 years ago

0.33.1

2 years ago

0.33.0

2 years ago

0.32.18

2 years ago

0.32.17

2 years ago

0.32.16

2 years ago

0.32.15

2 years ago

0.32.8

2 years ago

0.32.7

2 years ago

0.32.6

2 years ago

0.32.9

2 years ago

0.32.14

2 years ago

0.32.13

2 years ago

0.32.12

2 years ago

0.32.11

2 years ago

0.32.10

2 years ago

0.32.5

2 years ago

0.32.4

2 years ago

0.32.3

2 years ago

0.32.2

2 years ago

0.32.1

2 years ago

0.32.0

2 years ago

0.31.0-beta.10

2 years ago

0.31.9

2 years ago

0.31.8

2 years ago

0.31.7

2 years ago

0.31.6

2 years ago

0.31.5

2 years ago

0.31.4

2 years ago

0.31.3

2 years ago

0.31.2

2 years ago

0.31.1

2 years ago

0.31.0

2 years ago

0.31.10

2 years ago

0.31.11

2 years ago

0.31.12

2 years ago

0.31.13

2 years ago

0.31.0-beta.6

2 years ago

0.31.0-beta.5

2 years ago

0.31.0-beta.4

2 years ago

0.31.0-beta.3

2 years ago

0.31.0-beta.2

2 years ago

0.31.0-beta.1

2 years ago

0.31.0-beta.0

2 years ago

0.31.0-beta.9

2 years ago

0.31.0-beta.8

2 years ago

0.31.0-beta.7

2 years ago

0.30.9

2 years ago

0.30.8

2 years ago

0.30.7

3 years ago

0.30.6

3 years ago

0.30.5

3 years ago

0.30.4

3 years ago

0.30.3

3 years ago

0.30.2

3 years ago

0.29.19

3 years ago

0.30.1

3 years ago

0.30.0

3 years ago

0.29.18

3 years ago

0.29.17

3 years ago

0.29.16

3 years ago

0.29.15

3 years ago

0.29.14

3 years ago

0.29.13

3 years ago

0.29.12

3 years ago

0.29.11

3 years ago

0.29.10

3 years ago

0.29.9

3 years ago

0.29.8

3 years ago

0.29.7

3 years ago

0.29.6

3 years ago

0.29.5

3 years ago

0.29.4

3 years ago

0.29.3

3 years ago

0.29.2

3 years ago

0.29.0

3 years ago

0.29.1

3 years ago

0.28.11

3 years ago

0.28.10

3 years ago

0.28.9

3 years ago

0.28.8

3 years ago

0.28.7

3 years ago

0.28.6

3 years ago

0.28.5

3 years ago

0.27.7

3 years ago

0.28.1

3 years ago

0.28.0

3 years ago

0.28.4

3 years ago

0.28.3

3 years ago

0.28.2

3 years ago

0.27.2

3 years ago

0.27.1

3 years ago

0.27.0

3 years ago

0.27.6

3 years ago

0.27.5

3 years ago

0.27.4

3 years ago

0.27.3

3 years ago

0.26.4

3 years ago

0.26.3

3 years ago

0.26.2

3 years ago

0.26.1

3 years ago

0.26.0

3 years ago

0.25.16

3 years ago

0.25.15

3 years ago

0.25.14

3 years ago

0.25.13

3 years ago

0.25.12

3 years ago

0.25.11

3 years ago

0.25.10

3 years ago

0.25.9

3 years ago

0.25.8

3 years ago

0.25.7

3 years ago

0.25.6

3 years ago

0.25.4

3 years ago

0.25.5

3 years ago

0.25.3

3 years ago

0.25.2

3 years ago

0.25.1

3 years ago

0.25.0

3 years ago

0.25.0-beta.6

3 years ago

0.25.0-beta.5

3 years ago

0.25.0-beta.4

3 years ago

0.25.0-beta.2

3 years ago

0.25.0-beta.3

3 years ago

0.25.0-beta.1

3 years ago

0.25.0-beta.0

3 years ago

0.24.7

3 years ago

0.24.6

3 years ago

0.24.5

3 years ago

0.24.4

3 years ago

0.24.3

3 years ago

0.24.2

3 years ago

0.24.1

3 years ago

0.24.0

3 years ago

0.24.0-beta.0

3 years ago

0.23.5

3 years ago

0.23.4

3 years ago

0.23.3

3 years ago

0.23.2

3 years ago

0.23.1

3 years ago

0.23.0-beta.7

3 years ago

0.23.0

3 years ago

0.23.0-beta.5

3 years ago

0.23.0-beta.6

3 years ago

0.22.3

4 years ago

0.23.0-beta.4

4 years ago

0.23.0-beta.3

4 years ago

0.23.0-beta.2

4 years ago

0.23.0-beta.1

4 years ago

0.23.0-beta.0

4 years ago

0.22.2

4 years ago

0.22.1

4 years ago

0.22.0

4 years ago

0.22.0-beta.3

4 years ago

0.22.0-beta.2

4 years ago

0.22.0-beta.1

4 years ago

0.22.0-beta.0

4 years ago

0.21.1

4 years ago

0.21.0

4 years ago

0.20.11

4 years ago

0.20.10

4 years ago

0.20.9

4 years ago

0.20.8

4 years ago

0.20.7

4 years ago

0.20.6

4 years ago

0.20.5

4 years ago

0.20.4

4 years ago

0.20.3

4 years ago

0.20.2

4 years ago

0.20.1

4 years ago

0.20.0

4 years ago

0.20.0-beta.8

4 years ago

0.20.0-beta.6

4 years ago

0.20.0-beta.7

4 years ago

0.20.0-beta.5

4 years ago

0.20.0-beta.4

4 years ago

0.20.0-beta.3

4 years ago

0.20.0-beta.2

4 years ago

0.20.0-beta.1

4 years ago

0.20.0-beta.0

4 years ago

0.19.10

4 years ago

0.19.8

4 years ago

0.19.9

4 years ago

0.19.7

4 years ago

0.19.6

4 years ago

0.19.5

4 years ago

0.19.3

4 years ago

0.19.4

4 years ago

0.19.2

4 years ago

0.19.1

4 years ago

0.19.0

4 years ago

0.18.11

4 years ago

0.18.10

4 years ago

0.18.9

4 years ago

0.18.8

4 years ago

0.18.7

4 years ago

0.18.6

4 years ago

0.18.5

4 years ago

0.18.4

4 years ago

0.18.3

4 years ago

0.18.2

4 years ago

0.18.1

4 years ago

0.18.1-beta.0

4 years ago

0.18.0

4 years ago

0.18.0-beta.3

4 years ago

0.18.0-beta.2

4 years ago

0.18.0-beta.1

4 years ago

0.18.0-beta.0

4 years ago

0.17.5

4 years ago

0.17.4

4 years ago

0.17.3

4 years ago

0.17.2

4 years ago

0.17.1

4 years ago

0.17.0

4 years ago

0.17.0-beta.5

4 years ago

0.17.0-beta.4

4 years ago

0.17.0-beta.3

4 years ago

0.17.0-beta.2

4 years ago

0.17.0-beta.1

4 years ago

0.16.0

4 years ago

0.15.0

4 years ago

0.14.1

5 years ago

0.14.0

5 years ago

0.13.0

5 years ago

0.12.0

5 years ago

0.11.1

5 years ago

0.11.0

5 years ago

0.11.0-beta.1

5 years ago

0.11.0-beta.0

5 years ago

0.10.0

5 years ago

0.9.2

5 years ago

0.9.1

5 years ago

0.9.0

5 years ago

0.9.0-beta.0

5 years ago

0.8.0

5 years ago

0.8.0-beta.2

5 years ago

0.8.0-beta.1

5 years ago

0.8.0-beta.0

5 years ago

0.7.4

5 years ago

0.7.3

5 years ago

0.7.2

5 years ago

0.7.2-beta.1

5 years ago

0.7.1

5 years ago

0.7.0

5 years ago

0.0.1

5 years ago