WebReflection / signal

An extremely basic signals implementation.
https://calendar.perfplanet.com/2022/signals-the-nitty-gritty/
ISC License
59 stars 3 forks source link
javascript signals

@webreflection/signal

Coverage Status build status

Social Media Photo by Louis Reed on Unsplash

A minimalistic signals implementation, derived from the post Signals: the nitty-gritty, which size, once minified and brotlied, is 528 bytes.

For anything more complex please check usignal out.

exports

Computed accepts an initial value to pass to the callback. The callback will keep receiving the previous value on each new invoke.

example

// import {signal, effect} from 'https://unpkg.com/@webreflection/signal';
// const {signal, effect} = require('@webreflection/signal');
import {signal, effect} from '@webreflection/signal';

const single = signal(1);
const double = signal(10);
const triple = signal(100);

const dispose1 = effect(() => {
  console.log(`
  #1 effect
    single: ${single}
    double: ${double}
  `);
});

const dispose2 = effect(() => {
  console.log(`
  #2 effect
    double: ${double}
    triple: ${triple}
  `);
});

++double.value;
// logs single 1, double 11
// logs double 11, triple 100

dispose2();

++double.value;
// logs single 1, double 11