Skip to content

Latest commit

 

History

History
163 lines (130 loc) · 3.6 KB

BauReactivity.md

File metadata and controls

163 lines (130 loc) · 3.6 KB

Bau Reactivity

The bau.state function create a reactive state thanks the Javascript Proxy feature.

The idea is to intercept data mutations and update the DOM accordingly.

For Vue developers, bau.state is equivalent to ref

Creation

const myBoolState = bau.state(false);
const myNumberState = bau.state(1);
const myStringState = bau.state("foo");
const myArrayState = bau.state(["foo", "bar"]);
const myObjetState = bau.state({ name: "Freddy", rank: 2 });

Read/Write

The value is read and written with the val key.

const myStringState = bau.state("foo");
// Read
console.log(myStringState.val); // "foo"
// Write
myStringState.val = "bar";
// Read
console.log(myStringState.val); // "bar"

See the dedicated documentation for arrays

Object

const myObjetState = bau.state({ score: 0, rank: 2 });
// Read
console.log(myObjetState.val.rank); // 2
// Write
myObjetState.val.ranks = 3;
// Read
console.log(myObjetState.val.rank); // 3

Reactive State

When a state with primitive value is inside a element, it is automatically reactive:

Reactive Number

counterState holds an integer and is placed inside a div.

const TestReactiveStateNumber = () => {
  const counterState = bau.state(0);
  return article(
    h1("State Number"),
    button({ onclick: () => counterState.val++ }, "Increment"),
    div(counterState)
  );
};

Reactive String

messageState holds a string and is placed inside a span. When the button is clicked, the messageState value is mutated, the message in the span is automatically updated.

const TestReactiveStateString = () => {
  const messageState = bau.state("Ciao");
  return article(
    h1("State String"),
    button(
      { onclick: () => (messageState.val = `${messageState.val} Bello`) },
      "Add Bello"
    ),
    span(messageState)
  );
};

Reactive Element

Functions can be placed inside the element tree, the state dependencies are collected automatically, later on, when one of these states it mutated, the function is executed and return a new element.

const TestReactiveFunction = () => {
  const showState = bau.state(true);
  return article(
    h1("Reactive Function"),
    button(
      //
      { onclick: () => (showState.val = !showState.val) },
      () => (showState.val ? "HIDE" : "SHOW")
    ),
    () => showState.val && "Stuff to show"
  );
};

Reactive Property

style property

The style property can be reactive by assigning a function to the style property:

const TestReactiveStyle = () => {
  const colorState = bau.state(false);

  return article(
    h1("Reative style"),
    div(
      {
        style: () => (colorState.val ? "color:red;" : ""),
      },
      button(
        { onclick: () => (colorState.val = !colorState.val) },
        "Click to change the style"
      ),
      p("My Text")
    )
  );
};

class property

The class property can be reactive by assigning a function to the class property. First define a class in your css file:

// your css file
.active {
  color: green;
  border-bottom: 2px dashed green;
}

When the button is clicked, the class will toogle from empty to active.

// Your js file
const TestReactiveClass = () => {
  const colorState = bau.state(false);

  return article(
    h1("Reative class"),
    div(
      {
        class: () => (colorState.val ? "active" : ""),
      },
      button(
        { onclick: () => (colorState.val = !colorState.val) },
        "Click to change the style"
      ),
      p("My Text")
    )
  );
};