Products

Reactive Counter Example

How to write a simple reactive counter using LemonadeJS. See this example on codesandbox

<html>
<script src="https://lemonadejs.com/v4/lemonade.js"></script>
<div id='root'></div>
<script>
function Counter() {
    const self = this;

    self.count = 1;

    self.add = function() {
        self.count++;
    }

    self.remove = function() {
        self.count--;
    }

    self.reset = function(element) {
        self.count = 0;
    }

    return `<div>
        <p>Count {{self.count}}</p>
        <div>
            <input type="button" onclick="self.add" value="+" />
            <input type="button" onclick="self.remove" value="-" />
            <input type="button" onclick="self.reset" value="Reset" />
        </div>
    </div>`;
};
lemonade.render(Counter, document.getElementById('root'));
</script>
</html>
import lemonade from 'lemonadejs';

export default function Counter() {
    const self = this;

    self.count = 1;

    self.add = function() {
        self.count++;
    }

    self.remove = function() {
        self.count--;
    }

    self.reset = function(element) {
        self.count = 0;
    }

    return `<div class="counter">
        <h1>Count {{self.count}}</h1>
        <div>
            <input type="button" onclick="self.add" value="+" />
            <input type="button" onclick="self.remove" value="-" />
            <input type="button" onclick="self.reset" value="Reset" />
        </div>
    </div>`;
};