Skip to content

evatrium/superfinesse

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

superfinesse

inspired by superfine with a little extra finesse.

  • Capable of renderng into shadowRoot
  • Support for Fragments and root level Fragments
  • upgraded preact-inspired props diffing (style objects and more...)
  • Gzipped Size: 1.67 KB

Installation

npm i superfinesse

Usage

import {h, Fragment, render, mount} from 'superfinesse';
 
 let state = {count: 0};
 
 
 const root = document.createElement("div");
 document.body.appendChild(root);
 
 
 const update = (newState) => {
     state = {...state, ...newState};
     render(<App/>, root);
 };
 
 
 const Button = ({children, ...rest}) => {
 
     return (
         <button style={{
             background: 'red',
             height: 40 /*pixels/dimensional units inferred*/
         }} {...rest}>
             {children}
         </button>
     )
 };
 
 const App = () => {
 
     let {count} = state;
 
     return (
         <Fragment>
 
             <h1>count: {count}</h1>
 
             <Button onClick={() =>{
                 console.log('click')
                 update({count: count + 1})
             }}>
                 click me
             </Button>
 
             <div dangerouslySetInnerHTML={{__html:`
                 <h2>just like preact, diffing children will be skipped here</h2>
             `}}/>
 
         </Fragment>
     )
 };
 
 update();

About

modified version of superfine

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published