1.0.8 • Published 3 years ago
raccoon-js-framework v1.0.8
Raccoon JS
This is an experimental JS framework inspired by Vue.js. It's created for personal learning and exploration. Play around with it but don't use it for any production work.
Raccoon is a reactive - component based framework with basic functionality such as, reactivity, template engine, computed functions, dom-events, etc.
Setup
Install Raccoon and a simple dev server.
You can use any dev server or bundler, we're using http-server for this example.
npm install raccoon-js-framework
npm install http-server --save-dev # Or what ever server you like{
  "scripts": {
    "start": "http-server . -o"
  }
}npm run start<!-- Add in the header -->
<script src="app.js" type="module"></script>// Import Raccoon
import { Raccoon } from "raccoon-js-framework";
// Without bundler (Webpack, Vite etc), use relative path.
import { Raccoon } from "./node_modules/raccoon-js-framework/source/index.js";Write some javascript
import { Raccoon } from "raccoon-js-framework";
const componentEl = document.getElementById("demo-component-2");
// The Raccoon object returns 3 object
// 1. proxy, a reactive object. Changes to properties will be reflected on the page.
// 2. compute, a method that which returned value will be updated on the page when any proxy property updates.
// 3. funcs, an object to hold functions. This keeps the template clean and declarative. Good to handle e.g on-click logic.
const { proxy, compute, funcs } = new Raccoon(componentEl); 
proxy.price = 1;
proxy.quantity = 15;
proxy.tax = 0.01;
proxy.names = ["Lisa", "Frank", "Steve"];
compute.sum = () => (proxy.price * proxy.quantity) + (100 * proxy.tax);
compute.taxHuman = () => `${100 * proxy.tax}%`
funcs.addOnePercentTax = () => proxy.tax += 0.01Create a component
<div id="demo-component-2">
  <button @click="proxy.price += 10">Increase price</button>
  <button @click="proxy.quantity += 1">Increase quantity</button>
  <button @click="funcs.addOnePercentTax()">Add 1% tax</button>
  <div>Price: {{price}}</div>
  <div>Quantity: {{quantity}}</div>
  <div>Tax: {{taxHuman}}</div>
  <div>Sum (inc tax): {{sum}}</div>
  <div r-for="name of names">
    {{ name }}
  </div>
</div>