mirror of
https://github.com/jaandrle/deka-dom-el
synced 2025-04-03 12:35:52 +02:00
* :tap: removed on.attributeChanged and static observedAttributes * ⚡ import optimalization * ⚡ scope.signal * 🔤 🐛 * ⚡ 🐛 registerReactivity and types * 🔤 * ⚡ * 🔤 * 🐛 Node in enviroment * ⚡ todos * ⚡ * ⚡ 🔤 * ⚡ lint * ⚡ memo * 🔤 🐛 memo * ⚡ 🔤 todomvc * 🐛 types * 🔤 p08 signal factory * 🔤 ⚡ types * ⚡ 🔤 lint * 🔤 * 🔤 * 🔤 * 🔤 * 📺
384 lines
13 KiB
JavaScript
384 lines
13 KiB
JavaScript
import { T, t } from "./utils/index.js";
|
|
export const info= {
|
|
title: t`Appendix & Summary`,
|
|
fullTitle: t`dd<el> Comprehensive Reference`,
|
|
description: t`A final overview, case studies, key concepts, and best practices for working with deka-dom-el.`,
|
|
};
|
|
|
|
import { el } from "deka-dom-el";
|
|
import { simplePage } from "./layout/simplePage.html.js";
|
|
import { h3 } from "./components/pageUtils.html.js";
|
|
import { code } from "./components/code.html.js";
|
|
/** @param {string} url */
|
|
const references= {
|
|
/** GitHub repository */
|
|
github: {
|
|
title: t`dd<el> GitHub Repository`,
|
|
href: "https://github.com/jaandrle/deka-dom-el",
|
|
},
|
|
/** TodoMVC */
|
|
todomvc: {
|
|
title: t`TodoMVC Implementation`,
|
|
href: "p10-todomvc.html",
|
|
},
|
|
/** Performance best practices */
|
|
performance: {
|
|
title: t`Performance Optimization Guide`,
|
|
href: "p09-optimization.html",
|
|
}
|
|
};
|
|
|
|
/** @param {import("./types.d.ts").PageAttrs} attrs */
|
|
export function page({ pkg, info }){
|
|
const page_id= info.id;
|
|
return el(simplePage, { info, pkg }).append(
|
|
el("p").append(...T`
|
|
This reference guide provides a comprehensive summary of dd<el>'s key concepts, best practices,
|
|
case studies, and advanced techniques. Use it as a quick reference when working with the library
|
|
or to deepen your understanding of its design principles and patterns.
|
|
`),
|
|
|
|
el(h3, t`Core Principles of dd<el>`),
|
|
el("p").append(...T`
|
|
At its foundation, dd<el> is built on several core principles that shape its design and usage:
|
|
`),
|
|
el("div", { className: "callout" }).append(
|
|
el("h4", t`Guiding Principles`),
|
|
el("ul").append(
|
|
el("li").append(...T`
|
|
${el("strong", "DOM-First Approach:")} Working directly with the real DOM instead of virtual DOM
|
|
abstractions
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "Declarative Syntax:")} Creating UIs by describing what they should look like, not
|
|
how to create them
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "Minimal Overhead:")} Staying close to standard Web APIs without unnecessary
|
|
abstractions
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "Progressive Enhancement:")} Starting simple and adding complexity only when needed
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "Functional Composition:")} Building UIs through function composition rather than
|
|
inheritance
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "Clear Patterns:")} Promoting maintainable code organization with the 3PS pattern
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "Targeted Reactivity:")} Using signals for efficient, fine-grained updates
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "Unix Philosophy:")} Doing one thing well and allowing composability with other tools
|
|
`)
|
|
)
|
|
),
|
|
|
|
el(h3, t`Case Studies & Real-World Applications`),
|
|
|
|
el("h4", t`TodoMVC Implementation`),
|
|
el("p").append(...T`
|
|
The ${el("a", references.todomvc).append("TodoMVC implementation")} showcases how dd<el> handles a complete,
|
|
real-world application with all standard features of a modern web app:
|
|
`),
|
|
el("ul").append(
|
|
el("li", t`Persistent storage with localStorage`),
|
|
el("li", t`Reactive UI with automatic updates`),
|
|
el("li", t`Client-side routing with hash-based URLs`),
|
|
el("li", t`Component-based architecture`),
|
|
el("li", t`Performance optimization with memoization`),
|
|
el("li", t`Custom event system for component communication`),
|
|
el("li", t`Proper focus management and accessibility`)
|
|
),
|
|
el("p").append(...T`
|
|
Key takeaways from the TodoMVC example:
|
|
`),
|
|
el("ul").append(
|
|
el("li").append(...T`
|
|
Signal factories like ${el("code", "routerSignal")} and ${el("code", "todosSignal")}
|
|
encapsulate related functionality
|
|
`),
|
|
el("li").append(...T`
|
|
Custom events provide clean communication between components
|
|
`),
|
|
el("li").append(...T`
|
|
Targeted memoization improves rendering performance dramatically
|
|
`),
|
|
el("li").append(...T`
|
|
Derived signals simplify complex UI logic like filtering
|
|
`)
|
|
),
|
|
|
|
el("h4", t`Migrating from Traditional Approaches`),
|
|
el("p").append(...T`
|
|
When migrating from traditional DOM manipulation or other frameworks to dd<el>:
|
|
`),
|
|
el("ol").append(
|
|
el("li").append(...T`
|
|
${el("strong", "Start with state:")}: Convert global variables or ad-hoc state to signals
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "Replace query selectors:")}: Replace getElementById/querySelector with direct references to elements
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "Convert imperative updates:")}: Replace manual DOM updates with declarative signal bindings
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "Refactor into components:")}: Organize related UI elements into component functions
|
|
`)
|
|
),
|
|
el(code, { content: `
|
|
// Before: Imperative DOM updates
|
|
function updateUI() {
|
|
document.getElementById('counter').textContent = count;
|
|
document.getElementById('status').className = count > 10 ? 'warning' : '';
|
|
}
|
|
|
|
// After: Declarative with dd<el>
|
|
const countS = S(0);
|
|
|
|
el("div").append(
|
|
el("span", { id: "counter", textContent: countS }),
|
|
el("div", {
|
|
id: "status",
|
|
className: S(() => countS.get() > 10 ? 'warning' : '')
|
|
})
|
|
);
|
|
`, page_id }),
|
|
|
|
el(h3, t`Key Concepts Reference`),
|
|
|
|
el("div", { className: "function-table" }).append(
|
|
el("h4", t`Elements & DOM Creation`),
|
|
el("dl").append(
|
|
el("dt", t`el(tag|component, props, ...addons)`),
|
|
el("dd", t`Core function for creating DOM elements with declarative properties`),
|
|
|
|
el("dt", t`el().append(...children)`),
|
|
el("dd", t`Add child elements to a parent element`),
|
|
|
|
el("dt", t`memo(key, () => element)`),
|
|
el("dd", t`Cache and reuse DOM elements for performance optimization`),
|
|
|
|
el("dt", t`on(eventType, handler)`),
|
|
el("dd", t`Attach event handlers to elements as addons`)
|
|
)
|
|
),
|
|
|
|
el("div", { className: "function-table" }).append(
|
|
el("h4", t`Signals & Reactivity`),
|
|
el("dl").append(
|
|
el("dt", t`S(initialValue)`),
|
|
el("dd", t`Create a signal with an initial value`),
|
|
|
|
el("dt", t`S(() => computation)`),
|
|
el("dd", t`Create a derived signal that updates when dependencies change`),
|
|
|
|
el("dt", t`S.el(signal, data => element)`),
|
|
el("dd", t`Create reactive elements that update when a signal changes`),
|
|
|
|
el("dt", t`S.action(signal, "method", ...args)`),
|
|
el("dd", t`Call custom methods defined on a signal`),
|
|
|
|
el("dt", t`signal.get()`),
|
|
el("dd", t`Get the current value of a signal`),
|
|
|
|
el("dt", t`signal.set(newValue)`),
|
|
el("dd", t`Update a signal's value and trigger reactive updates`)
|
|
)
|
|
),
|
|
|
|
el("div", { className: "function-table" }).append(
|
|
el("h4", t`Component Patterns`),
|
|
el("dl").append(
|
|
el("dt", t`Function Components`),
|
|
el("dd", t`Javascript functions that return DOM elements`),
|
|
|
|
el("dt", t`scope Object`),
|
|
el("dd", t`Provides access to component context, signal, host element`),
|
|
|
|
el("dt", t`dispatchEvent(type, element)`),
|
|
el("dd", t`Creates a function for dispatching custom events`),
|
|
|
|
el("dt", t`Signal Factories`),
|
|
el("dd", t`Functions that create and configure signals with domain-specific behavior`)
|
|
)
|
|
),
|
|
|
|
el(h3, t`Best Practices Summary`),
|
|
el("div").append(
|
|
el("h4", t`Code Organization`),
|
|
el("ul").append(
|
|
el("li").append(...T`
|
|
${el("strong", "Follow the 3PS pattern:")}: Separate state creation, binding to elements, and state updates
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "Use component functions:")}: Create reusable UI components as functions
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "Create signal factories:")}: Extract reusable signal patterns into factory functions
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "Leverage scopes:")}: Use scope for component context and clean resource management
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "Event delegation:")}: Prefer component-level event handlers over many individual handlers
|
|
`)
|
|
)
|
|
),
|
|
|
|
el("div").append(
|
|
el("h4", t`Performance Optimization`),
|
|
el("ul").append(
|
|
el("li").append(...T`
|
|
${el("strong", "Memoize list items:")}: Use ${el("code", "memo")} for items in frequently-updated lists
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "Avoid unnecessary signal updates:")}: Only update signals when values actually change
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "Use AbortSignals:")}: Clean up resources when components are removed
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "Prefer derived signals:")}: Use computed values instead of manual updates
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "Avoid memoizing fragments:")}: Never memoize DocumentFragments, only individual elements
|
|
`)
|
|
),
|
|
el("p").append(...T`
|
|
See the ${el("a", references.performance).append("Performance Optimization Guide")} for detailed strategies.
|
|
`)
|
|
),
|
|
|
|
el("div").append(
|
|
el("h4", t`Common Pitfalls to Avoid`),
|
|
el("dl").append(
|
|
el("dt", t`Excessive DOM Manipulation`),
|
|
el("dd", t`Let signals handle updates instead of manually manipulating the DOM after creation`),
|
|
|
|
el("dt", t`Forgetting to Clean Up Resources`),
|
|
el("dd", t`Use scope.signal or AbortSignals to handle resource cleanup when elements are removed`),
|
|
|
|
el("dt", t`Circular Signal Dependencies`),
|
|
el("dd", t`Avoid signals that depend on each other in a circular way, which can cause infinite update loops`),
|
|
|
|
el("dt", t`Memoizing with Unstable Keys`),
|
|
el("dd", t`Always use stable, unique identifiers as memo keys, not array indices or objects`),
|
|
|
|
el("dt", t`Deep Nesting Without Structure`),
|
|
el("dd", t`Break deeply nested element structures into smaller, logical component functions`)
|
|
)
|
|
),
|
|
|
|
el(h3, t`Feature Comparison with Other Libraries`),
|
|
el("table").append(
|
|
el("thead").append(
|
|
el("tr").append(
|
|
el("th", "Feature"),
|
|
el("th", "dd<el>"),
|
|
el("th", "React"),
|
|
el("th", "Vue"),
|
|
el("th", "Svelte")
|
|
)
|
|
),
|
|
el("tbody").append(
|
|
el("tr").append(
|
|
el("td", "No Build Step Required"),
|
|
el("td", "✅"),
|
|
el("td", "⚠️ JSX needs transpilation"),
|
|
el("td", "⚠️ SFC needs compilation"),
|
|
el("td", "❌ Requires compilation")
|
|
),
|
|
el("tr").append(
|
|
el("td", "Bundle Size (minimal)"),
|
|
el("td", "~10-15kb"),
|
|
el("td", "~40kb+"),
|
|
el("td", "~33kb+"),
|
|
el("td", "Minimal runtime")
|
|
),
|
|
el("tr").append(
|
|
el("td", "Reactivity Model"),
|
|
el("td", "Signal-based"),
|
|
el("td", "Virtual DOM diffing"),
|
|
el("td", "Proxy-based"),
|
|
el("td", "Compile-time reactivity")
|
|
),
|
|
el("tr").append(
|
|
el("td", "DOM Interface"),
|
|
el("td", "Direct DOM API"),
|
|
el("td", "Virtual DOM"),
|
|
el("td", "Virtual DOM"),
|
|
el("td", "Compiled DOM updates")
|
|
),
|
|
el("tr").append(
|
|
el("td", "Server-Side Rendering"),
|
|
el("td", "✅ Basic Support"),
|
|
el("td", "✅ Advanced"),
|
|
el("td", "✅ Advanced"),
|
|
el("td", "✅ Advanced")
|
|
)
|
|
)
|
|
),
|
|
|
|
el(h3, t`Looking Ahead: Future Directions`),
|
|
el("p").append(...T`
|
|
The dd<el> library continues to evolve, with several areas of focus for future development:
|
|
`),
|
|
el("ul").append(
|
|
el("li").append(...T`
|
|
${el("strong", "Future Compatibility:")} Alignment with the TC39 Signals proposal for native browser support
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "SSR Improvements:")} Enhanced server-side rendering capabilities
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "Ecosystem Growth:")} More utilities, patterns, and integrations with other libraries
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "Documentation Expansion:")} Additional examples, tutorials, and best practices
|
|
`),
|
|
el("li").append(...T`
|
|
${el("strong", "TypeScript Enhancements:")} Improved type definitions and inference
|
|
`)
|
|
),
|
|
|
|
el(h3, t`Contribution and Community`),
|
|
el("p").append(...T`
|
|
dd<el> is an open-source project that welcomes contributions from the community:
|
|
`),
|
|
el("ul").append(
|
|
el("li").append(...T`
|
|
${el("a", references.github).append("GitHub Repository")}: Star, fork, and contribute to the project
|
|
`),
|
|
el("li").append(...T`
|
|
Bug reports and feature requests: Open issues on GitHub
|
|
`),
|
|
el("li").append(...T`
|
|
Documentation improvements: Help expand and clarify these guides
|
|
`),
|
|
el("li").append(...T`
|
|
Examples and case studies: Share your implementations and solutions
|
|
`)
|
|
),
|
|
|
|
el("div", { className: "callout" }).append(
|
|
el("h4", t`Final Thoughts`),
|
|
el("p").append(...T`
|
|
dd<el> provides a lightweight yet powerful approach to building modern web interfaces
|
|
with minimal overhead and maximal flexibility. By embracing standard web technologies
|
|
rather than abstracting them away, it offers a development experience that scales
|
|
from simple interactive elements to complex applications while remaining close
|
|
to what makes the web platform powerful.
|
|
`),
|
|
el("p").append(...T`
|
|
Whether you're building a small interactive component or a full-featured application,
|
|
dd<el>'s combination of declarative syntax, targeted reactivity, and pragmatic design
|
|
provides the tools you need without the complexity you don't.
|
|
`)
|
|
),
|
|
);
|
|
}
|