Add skooma-like functional DOM rendering helper

This commit is contained in:
Talia 2021-02-17 11:03:21 +01:00
commit cf4455ca7a
Signed by: darkwiiplayer
GPG key ID: 7808674088232B3E

26
render.js Normal file
View file

@ -0,0 +1,26 @@
const parseArgs = (element, args) => {
for (arg of args)
if (typeof(arg) == "string")
element.appendChild(document.createTextNode(arg))
else if ("nodeName" in arg)
element.appendChild(arg)
else if ("length" in arg)
parseArgs(element, arg)
else
for (key in arg)
element.setAttribute(key, arg[key])
}
export const node = (name, args) => {
const element = document.createElement(name)
parseArgs(element, args)
return element
}
export const html = new Proxy(Window, { get: (target, prop, receiver) => {
// This distinction is only helpful because javascript is fucking restarted
if (prop.search(/^[A-Z]/)+1)
return (arg) => node(prop, [arg])
else
return (...args) => node(prop, args)
}})