Reken logo; blue html representing elements intertwined with orange reken elements

Reken Dutch singular verb for calculate. Pronounce: Ray - ken

Quickly create data-driven HTML pages with an 'HTML First' approach, using powerful new HTML attributes.

For live demos, REPL and more information, visit the Reken website.

Support the Reken project

Support the Reken project by purchasing the Reken Developer Handbook↗, all you need to get up to speed with Reken. Support the Reken project by purchasing the Reken Developer Handbook, all you need to get up to speed with Reken

Why use Reken?

Easy creation of Dynamic Web pages with just HTML, CSS and a few sprinkles of Javascript.

Who is Reken for?

How does Reken work?

Reken relies on a few data-* attributes that empower any HTML element to:

When a page with Reken attributes is loaded, Reken will build a setup controller and a runtime controller.

It will then run the setup controller once to register any event listeners.

After setup is completed it will run the runtime controller which will update any dynamic DOM when needed. The runtime controller will run again after any Reken-managed event listener fires or rest call finishes.

Example

<script>
    let name = 'World';
</script>

<h1 data-text="Hello ${name}"></h1>

Installation

Install Reken.js on your server and add a script tag at the bottom of your web page between the the end body and before the end html tag.

<html>
  <body></body>
  <script src="reken.js"></script>
</html>

Browser support

Reken relies on a number of ES6 features and therefor supports the following browsers:

Attribute API

Look at the demos and the Reken REPL for more examples and usages.

JavaScript API

On the global namespace you can find the reken object.

It has the following public members:

Gotchas / limitations

In this section we discuss some of Reken's gotchas / limitations, hopefully this will help avoid you pulling your head out when you encounter them. We hope to address some of these at some point in the future, but nor guarantees.

Don't

data-action="myvar=x>10?20:10"

Do

data-action="true:myvar=x>10?20:10"
<template data-component="my-comp" data-bind-myVar>
...
<template data-component="my-comp" data-bind-my-var>
...

Do

<template data-component="my-comp" data-bind-my_var>
...

Don't

<template data-component="card-multi">
  <header>Hello</header>
  <main>Main body</main>
  <footer></footer>
</template>

Do

<template data-component="card-single">
<section>
  <header>Hello</header>
  <main>Main body</main>
  <footer></footer>
</section>
</template>

Don't

<template data-component="my-comp">
  <custom-component></custom-component>
</template>

Do

<template data-component="my-comp">
  <div>
    <custom-component></custom-component>
  </div>
</template>

Acknowledgments

License

Distributed under the MIT license. See the License file for details.