mirror of
https://github.com/jaandrle/deka-dom-el
synced 2025-10-24 11:59:31 +02:00
Compare commits
1 Commits
0772a382ed
...
5ae6bfdd35
Author | SHA1 | Date | |
---|---|---|---|
5ae6bfdd35 |
54
README.md
54
README.md
@@ -6,38 +6,38 @@
|
||||
|
||||
*…use simple DOM API by default and library tools and logic when you need them*
|
||||
|
||||
```javascript
|
||||
```js
|
||||
document.body.append(
|
||||
el(HelloWorldComponent)
|
||||
);
|
||||
function HelloWorldComponent(){
|
||||
const clicks= S(0);
|
||||
const emoji= S("🚀");
|
||||
const isSelected= el=> (el.selected= el.value===emoji());
|
||||
|
||||
return el().append(
|
||||
el("p", {
|
||||
textContent: S(() => `Hello World ${emoji().repeat(clicks())}`),
|
||||
className: "example",
|
||||
ariaLive: "polite", //OR ariaset: { live: "polite" },
|
||||
dataset: { example: "Example" }, //OR dataExample: "Example",
|
||||
}),
|
||||
el("button",
|
||||
{ textContent: "Fire", type: "button" },
|
||||
on("click", ()=> clicks(clicks() + 1)),
|
||||
on("keyup", ()=> clicks(clicks() - 2)),
|
||||
el("h1", "Hello World 👋"),
|
||||
el("p", "See some syntax examples here:"),
|
||||
el("ul").append(
|
||||
el("li").append(
|
||||
el("a", { textContent: "Link to the library repo",
|
||||
title: "Deka DOM El — GitHub",
|
||||
href: "https://github.com/jaandrle/deka-dom-el" })
|
||||
),
|
||||
el("select", {
|
||||
onchange: event=> emoji(event.target.value),
|
||||
}).append(
|
||||
el(OptionComponent, "🎉", isSelected),
|
||||
el(OptionComponent, "🚀", isSelected),
|
||||
el("li").append(
|
||||
"Use extended Vanilla JavaScript DOM/IDL API: ",
|
||||
el("span", { textContent: "» this is a span with class=cN and data-a=A, data-b=B «",
|
||||
className: "cN", dataset: { a: "A", b: "B" } })
|
||||
),
|
||||
el("li").append(
|
||||
el(component, { textContent: "A component", className: "example" }, on("change", console.log))
|
||||
)
|
||||
)
|
||||
|
||||
);
|
||||
function component({ textContent, className }){
|
||||
const value= S("onchange");
|
||||
|
||||
return el().append(
|
||||
el("p", { textContent, className }),
|
||||
el("p", { className: [ className, "second-line" ] }).append(
|
||||
"…with reactivity: ", el("em", { style: { fontWeight: "bold" }, ariaset: { live: "polite" }, textContent: value }),
|
||||
),
|
||||
el("input", { type: "text", value: value() }, on("change", event=> value(event.target.value)))
|
||||
);
|
||||
}
|
||||
function OptionComponent({ textContent }){
|
||||
return el("option", { value: textContent, textContent })
|
||||
}
|
||||
```
|
||||
# Deka DOM Elements
|
||||
Creating reactive elements, components and Web components using [IDL](https://developer.mozilla.org/en-US/docs/
|
||||
|
Reference in New Issue
Block a user