small-cup
v0.3.3
Published
a small javascript front end framework
Downloads
43
Readme
small-cup
a small javascript front end framework
Getting started
mkdir myapp
cd myapp
npm init small-cup@latest
API
enum DOMType { static dynamic }
type DOM {
node: HTMLNode
children: [DOM]
map: {[String]: DOM}
type: DOMType
root: Boolean
update: () => {}
unload: () => {}
}
type Component {
template: String
onload: (el: HTMLNode, ctx: Object, rootDom: DOM) => undefined | Component
components: {[key: String]: Component}
}
type ElementVNodeData {
tag: String
props: Object
children: undefined | [ChildVNode]
}
type TextVNodeData = String
type VNodeData = ElementVNodeData | TextVNodeData
enum VNodeType { element text }
type VNode {
type: VNodeType
data: VNodeData
}
type ChildVNode = String | VNode
render(root: HTMLNode, vnode: VNode, context: Object) => DOM
render vnode to root with context
mount(root: HTMLNode, vnode: VNode, context: Object)
render vnode to root with context when window.onpopstate triggerd
h(tag: String | HTMLNode, props: Object, children: undefined | [ChildVNode]) => VNode | HTMLNode
patch or create HTMLNode
Usage
<script type="module">
import { render, mount, h } from 'https://unpkg.com/small-cup/index.js'
</script>
npm i small-cup
Test
npm start
License
MIT