@mytechtoday/augment-extensions 0.2.0 → 0.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +614 -39
- package/augment-extensions/coding-standards/bash/README.md +196 -0
- package/augment-extensions/coding-standards/bash/module.json +163 -0
- package/augment-extensions/coding-standards/bash/rules/naming-conventions.md +336 -0
- package/augment-extensions/coding-standards/bash/rules/universal-standards.md +289 -0
- package/augment-extensions/coding-standards/css/README.md +40 -0
- package/augment-extensions/coding-standards/css/examples/css-examples.css +550 -0
- package/augment-extensions/coding-standards/css/module.json +44 -0
- package/augment-extensions/coding-standards/css/rules/css-modern-features.md +448 -0
- package/augment-extensions/coding-standards/css/rules/css-standards.md +492 -0
- package/augment-extensions/coding-standards/html/README.md +40 -0
- package/augment-extensions/coding-standards/html/examples/html-examples.html +267 -0
- package/augment-extensions/coding-standards/html/examples/responsive-layout.html +505 -0
- package/augment-extensions/coding-standards/html/module.json +44 -0
- package/augment-extensions/coding-standards/html/rules/html-standards.md +349 -0
- package/augment-extensions/coding-standards/html-css-js/README.md +194 -0
- package/augment-extensions/coding-standards/html-css-js/examples/async-examples.js +487 -0
- package/augment-extensions/coding-standards/html-css-js/examples/css-examples.css +550 -0
- package/augment-extensions/coding-standards/html-css-js/examples/dom-examples.js +667 -0
- package/augment-extensions/coding-standards/html-css-js/examples/html-examples.html +267 -0
- package/augment-extensions/coding-standards/html-css-js/examples/javascript-examples.js +612 -0
- package/augment-extensions/coding-standards/html-css-js/examples/responsive-layout.html +505 -0
- package/augment-extensions/coding-standards/html-css-js/module.json +48 -0
- package/augment-extensions/coding-standards/html-css-js/rules/async-patterns.md +515 -0
- package/augment-extensions/coding-standards/html-css-js/rules/css-modern-features.md +448 -0
- package/augment-extensions/coding-standards/html-css-js/rules/css-standards.md +492 -0
- package/augment-extensions/coding-standards/html-css-js/rules/dom-manipulation.md +439 -0
- package/augment-extensions/coding-standards/html-css-js/rules/html-standards.md +349 -0
- package/augment-extensions/coding-standards/html-css-js/rules/javascript-standards.md +486 -0
- package/augment-extensions/coding-standards/html-css-js/rules/performance.md +463 -0
- package/augment-extensions/coding-standards/html-css-js/rules/tooling.md +543 -0
- package/augment-extensions/coding-standards/js/README.md +46 -0
- package/augment-extensions/coding-standards/js/examples/async-examples.js +487 -0
- package/augment-extensions/coding-standards/js/examples/dom-examples.js +667 -0
- package/augment-extensions/coding-standards/js/examples/javascript-examples.js +612 -0
- package/augment-extensions/coding-standards/js/module.json +49 -0
- package/augment-extensions/coding-standards/js/rules/async-patterns.md +515 -0
- package/augment-extensions/coding-standards/js/rules/dom-manipulation.md +439 -0
- package/augment-extensions/coding-standards/js/rules/javascript-standards.md +486 -0
- package/augment-extensions/coding-standards/js/rules/performance.md +463 -0
- package/augment-extensions/coding-standards/js/rules/tooling.md +543 -0
- package/augment-extensions/coding-standards/php/README.md +248 -0
- package/augment-extensions/coding-standards/php/examples/api-endpoint-example.php +204 -0
- package/augment-extensions/coding-standards/php/examples/cli-command-example.php +206 -0
- package/augment-extensions/coding-standards/php/examples/legacy-refactoring-example.php +234 -0
- package/augment-extensions/coding-standards/php/examples/web-application-example.php +211 -0
- package/augment-extensions/coding-standards/php/examples/woocommerce-extension-example.php +215 -0
- package/augment-extensions/coding-standards/php/examples/wordpress-plugin-example.php +189 -0
- package/augment-extensions/coding-standards/php/module.json +166 -0
- package/augment-extensions/coding-standards/php/rules/api-development.md +480 -0
- package/augment-extensions/coding-standards/php/rules/category-configuration.md +332 -0
- package/augment-extensions/coding-standards/php/rules/cli-tools.md +472 -0
- package/augment-extensions/coding-standards/php/rules/cms-integration.md +561 -0
- package/augment-extensions/coding-standards/php/rules/code-quality.md +402 -0
- package/augment-extensions/coding-standards/php/rules/documentation.md +425 -0
- package/augment-extensions/coding-standards/php/rules/ecommerce.md +627 -0
- package/augment-extensions/coding-standards/php/rules/error-handling.md +336 -0
- package/augment-extensions/coding-standards/php/rules/legacy-migration.md +677 -0
- package/augment-extensions/coding-standards/php/rules/naming-conventions.md +279 -0
- package/augment-extensions/coding-standards/php/rules/performance.md +392 -0
- package/augment-extensions/coding-standards/php/rules/psr-standards.md +186 -0
- package/augment-extensions/coding-standards/php/rules/security.md +358 -0
- package/augment-extensions/coding-standards/php/rules/testing.md +403 -0
- package/augment-extensions/coding-standards/php/rules/type-declarations.md +331 -0
- package/augment-extensions/coding-standards/php/rules/web-applications.md +426 -0
- package/augment-extensions/coding-standards/powershell/README.md +154 -0
- package/augment-extensions/coding-standards/powershell/examples/admin-example.ps1 +272 -0
- package/augment-extensions/coding-standards/powershell/examples/automation-example.ps1 +173 -0
- package/augment-extensions/coding-standards/powershell/examples/cloud-example.ps1 +243 -0
- package/augment-extensions/coding-standards/powershell/examples/cross-platform-example.ps1 +297 -0
- package/augment-extensions/coding-standards/powershell/examples/dsc-example.ps1 +224 -0
- package/augment-extensions/coding-standards/powershell/examples/legacy-migration-example.ps1 +340 -0
- package/augment-extensions/coding-standards/powershell/examples/module-example.psm1 +255 -0
- package/augment-extensions/coding-standards/powershell/module.json +165 -0
- package/augment-extensions/coding-standards/powershell/rules/administrative-tools.md +439 -0
- package/augment-extensions/coding-standards/powershell/rules/automation-scripts.md +240 -0
- package/augment-extensions/coding-standards/powershell/rules/cloud-orchestration.md +384 -0
- package/augment-extensions/coding-standards/powershell/rules/configuration-schema.md +383 -0
- package/augment-extensions/coding-standards/powershell/rules/cross-platform-scripts.md +482 -0
- package/augment-extensions/coding-standards/powershell/rules/dsc-configurations.md +296 -0
- package/augment-extensions/coding-standards/powershell/rules/error-handling.md +314 -0
- package/augment-extensions/coding-standards/powershell/rules/legacy-migrations.md +466 -0
- package/augment-extensions/coding-standards/powershell/rules/modules-functions.md +244 -0
- package/augment-extensions/coding-standards/powershell/rules/naming-conventions.md +266 -0
- package/augment-extensions/coding-standards/powershell/rules/performance-optimization.md +209 -0
- package/augment-extensions/coding-standards/powershell/rules/security-practices.md +314 -0
- package/augment-extensions/coding-standards/powershell/rules/testing-guidelines.md +268 -0
- package/augment-extensions/coding-standards/powershell/rules/universal-standards.md +197 -0
- package/augment-extensions/coding-standards/python/README.md +12 -8
- package/augment-extensions/coding-standards/python/examples/best-practices.py +373 -0
- package/augment-extensions/coding-standards/python/module.json +8 -4
- package/augment-extensions/coding-standards/python/rules/async-patterns.md +884 -0
- package/augment-extensions/coding-standards/python/rules/documentation.md +831 -0
- package/augment-extensions/coding-standards/python/rules/error-handling.md +855 -68
- package/augment-extensions/coding-standards/python/rules/testing.md +409 -0
- package/augment-extensions/coding-standards/python/rules/tooling.md +446 -0
- package/augment-extensions/coding-standards/python/rules/type-hints.md +115 -50
- package/augment-extensions/collections/html-css-js/README.md +82 -0
- package/augment-extensions/collections/html-css-js/collection.json +41 -0
- package/augment-extensions/domain-rules/database/README.md +161 -0
- package/augment-extensions/domain-rules/database/examples/flat-database-example.md +793 -0
- package/augment-extensions/domain-rules/database/examples/hybrid-database-example.md +1132 -0
- package/augment-extensions/domain-rules/database/examples/nosql-document-example.md +868 -0
- package/augment-extensions/domain-rules/database/examples/nosql-graph-example.md +805 -0
- package/augment-extensions/domain-rules/database/examples/relational-schema-example.md +621 -0
- package/augment-extensions/domain-rules/database/examples/vector-database-example.md +965 -0
- package/augment-extensions/domain-rules/database/module.json +28 -0
- package/augment-extensions/domain-rules/database/rules/flat-databases.md +624 -0
- package/augment-extensions/domain-rules/database/rules/nosql-databases.md +588 -0
- package/augment-extensions/domain-rules/database/rules/nosql-document-stores.md +856 -0
- package/augment-extensions/domain-rules/database/rules/nosql-graph-databases.md +778 -0
- package/augment-extensions/domain-rules/database/rules/nosql-key-value-stores.md +963 -0
- package/augment-extensions/domain-rules/database/rules/performance-optimization.md +1076 -0
- package/augment-extensions/domain-rules/database/rules/relational-databases.md +697 -0
- package/augment-extensions/domain-rules/database/rules/relational-indexing.md +671 -0
- package/augment-extensions/domain-rules/database/rules/relational-query-optimization.md +607 -0
- package/augment-extensions/domain-rules/database/rules/relational-schema-design.md +907 -0
- package/augment-extensions/domain-rules/database/rules/relational-transactions.md +783 -0
- package/augment-extensions/domain-rules/database/rules/security-standards.md +980 -0
- package/augment-extensions/domain-rules/database/rules/universal-best-practices.md +485 -0
- package/augment-extensions/domain-rules/database/rules/vector-databases.md +521 -0
- package/augment-extensions/domain-rules/database/rules/vector-embeddings.md +858 -0
- package/augment-extensions/domain-rules/database/rules/vector-indexing.md +934 -0
- package/augment-extensions/domain-rules/mcp/README.md +150 -0
- package/augment-extensions/domain-rules/mcp/examples/compressed-example.md +522 -0
- package/augment-extensions/domain-rules/mcp/examples/graph-augmented-example.md +520 -0
- package/augment-extensions/domain-rules/mcp/examples/hybrid-example.md +570 -0
- package/augment-extensions/domain-rules/mcp/examples/state-based-example.md +427 -0
- package/augment-extensions/domain-rules/mcp/examples/token-based-example.md +435 -0
- package/augment-extensions/domain-rules/mcp/examples/vector-based-example.md +502 -0
- package/augment-extensions/domain-rules/mcp/module.json +49 -0
- package/augment-extensions/domain-rules/mcp/rules/compressed-mcp.md +595 -0
- package/augment-extensions/domain-rules/mcp/rules/configuration.md +345 -0
- package/augment-extensions/domain-rules/mcp/rules/graph-augmented-mcp.md +687 -0
- package/augment-extensions/domain-rules/mcp/rules/hybrid-mcp.md +636 -0
- package/augment-extensions/domain-rules/mcp/rules/state-based-mcp.md +484 -0
- package/augment-extensions/domain-rules/mcp/rules/testing-validation.md +360 -0
- package/augment-extensions/domain-rules/mcp/rules/token-based-mcp.md +393 -0
- package/augment-extensions/domain-rules/mcp/rules/universal-rules.md +194 -0
- package/augment-extensions/domain-rules/mcp/rules/vector-based-mcp.md +625 -0
- package/augment-extensions/workflows/beads/module.json +4 -3
- package/augment-extensions/workflows/database/README.md +195 -0
- package/augment-extensions/workflows/database/ai-prompt-testing.md +295 -0
- package/augment-extensions/workflows/database/examples/migration-example.md +498 -0
- package/augment-extensions/workflows/database/examples/optimization-example.md +496 -0
- package/augment-extensions/workflows/database/examples/schema-design-example.md +444 -0
- package/augment-extensions/workflows/database/module.json +42 -0
- package/augment-extensions/workflows/database/rules/data-migration.md +249 -0
- package/augment-extensions/workflows/database/rules/documentation-standards.md +339 -0
- package/augment-extensions/workflows/database/rules/migration-workflow.md +352 -0
- package/augment-extensions/workflows/database/rules/optimization-workflow.md +435 -0
- package/augment-extensions/workflows/database/rules/schema-design-workflow.md +535 -0
- package/augment-extensions/workflows/database/rules/testing-patterns.md +305 -0
- package/augment-extensions/workflows/database/rules/workflow.md +458 -0
- package/augment-extensions/workflows/openspec/module.json +4 -3
- package/augment-extensions/writing-standards/screenplay/README.md +171 -0
- package/augment-extensions/writing-standards/screenplay/examples/aaa-hollywood-scene.fountain +164 -0
- package/augment-extensions/writing-standards/screenplay/module.json +124 -0
- package/augment-extensions/writing-standards/screenplay/rules/universal-formatting.md +339 -0
- package/cli/MODULES.md +302 -0
- package/cli/dist/cli.js +142 -9
- package/cli/dist/cli.js.map +1 -1
- package/cli/dist/commands/catalog.d.ts +13 -0
- package/cli/dist/commands/catalog.d.ts.map +1 -0
- package/cli/dist/commands/catalog.js +104 -0
- package/cli/dist/commands/catalog.js.map +1 -0
- package/cli/dist/commands/gui.d.ts +6 -0
- package/cli/dist/commands/gui.d.ts.map +1 -0
- package/cli/dist/commands/gui.js +211 -0
- package/cli/dist/commands/gui.js.map +1 -0
- package/cli/dist/commands/init.d.ts.map +1 -1
- package/cli/dist/commands/init.js +12 -0
- package/cli/dist/commands/init.js.map +1 -1
- package/cli/dist/commands/install-rules.d.ts +14 -0
- package/cli/dist/commands/install-rules.d.ts.map +1 -0
- package/cli/dist/commands/install-rules.js +127 -0
- package/cli/dist/commands/install-rules.js.map +1 -0
- package/cli/dist/commands/link.d.ts.map +1 -1
- package/cli/dist/commands/link.js +9 -11
- package/cli/dist/commands/link.js.map +1 -1
- package/cli/dist/commands/list.d.ts.map +1 -1
- package/cli/dist/commands/list.js +11 -28
- package/cli/dist/commands/list.js.map +1 -1
- package/cli/dist/commands/mcp.d.ts +48 -0
- package/cli/dist/commands/mcp.d.ts.map +1 -0
- package/cli/dist/commands/mcp.js +229 -0
- package/cli/dist/commands/mcp.js.map +1 -0
- package/cli/dist/commands/self-remove.d.ts +7 -0
- package/cli/dist/commands/self-remove.d.ts.map +1 -0
- package/cli/dist/commands/self-remove.js +179 -0
- package/cli/dist/commands/self-remove.js.map +1 -0
- package/cli/dist/commands/show.d.ts.map +1 -1
- package/cli/dist/commands/show.js +29 -99
- package/cli/dist/commands/show.js.map +1 -1
- package/cli/dist/commands/skill.d.ts +67 -0
- package/cli/dist/commands/skill.d.ts.map +1 -0
- package/cli/dist/commands/skill.js +513 -0
- package/cli/dist/commands/skill.js.map +1 -0
- package/cli/dist/commands/unlink.d.ts +6 -0
- package/cli/dist/commands/unlink.d.ts.map +1 -0
- package/cli/dist/commands/unlink.js +115 -0
- package/cli/dist/commands/unlink.js.map +1 -0
- package/cli/dist/commands/validate.d.ts +6 -0
- package/cli/dist/commands/validate.d.ts.map +1 -0
- package/cli/dist/commands/validate.js +159 -0
- package/cli/dist/commands/validate.js.map +1 -0
- package/cli/dist/utils/catalog-sync.d.ts +22 -0
- package/cli/dist/utils/catalog-sync.d.ts.map +1 -0
- package/cli/dist/utils/catalog-sync.js +157 -0
- package/cli/dist/utils/catalog-sync.js.map +1 -0
- package/cli/dist/utils/character-count.d.ts +56 -0
- package/cli/dist/utils/character-count.d.ts.map +1 -0
- package/cli/dist/utils/character-count.js +190 -0
- package/cli/dist/utils/character-count.js.map +1 -0
- package/cli/dist/utils/documentation-validator.d.ts +18 -0
- package/cli/dist/utils/documentation-validator.d.ts.map +1 -0
- package/cli/dist/utils/documentation-validator.js +233 -0
- package/cli/dist/utils/documentation-validator.js.map +1 -0
- package/cli/dist/utils/install-rules.d.ts +32 -0
- package/cli/dist/utils/install-rules.d.ts.map +1 -0
- package/cli/dist/utils/install-rules.js +375 -0
- package/cli/dist/utils/install-rules.js.map +1 -0
- package/cli/dist/utils/mcp-integration.d.ts +70 -0
- package/cli/dist/utils/mcp-integration.d.ts.map +1 -0
- package/cli/dist/utils/mcp-integration.js +292 -0
- package/cli/dist/utils/mcp-integration.js.map +1 -0
- package/cli/dist/utils/module-system.d.ts +153 -0
- package/cli/dist/utils/module-system.d.ts.map +1 -0
- package/cli/dist/utils/module-system.js +528 -0
- package/cli/dist/utils/module-system.js.map +1 -0
- package/cli/dist/utils/modules-catalog.d.ts +33 -0
- package/cli/dist/utils/modules-catalog.d.ts.map +1 -0
- package/cli/dist/utils/modules-catalog.js +163 -0
- package/cli/dist/utils/modules-catalog.js.map +1 -0
- package/cli/dist/utils/rule-install-hooks.d.ts +19 -0
- package/cli/dist/utils/rule-install-hooks.d.ts.map +1 -0
- package/cli/dist/utils/rule-install-hooks.js +224 -0
- package/cli/dist/utils/rule-install-hooks.js.map +1 -0
- package/cli/dist/utils/skill-system.d.ts +95 -0
- package/cli/dist/utils/skill-system.d.ts.map +1 -0
- package/cli/dist/utils/skill-system.js +313 -0
- package/cli/dist/utils/skill-system.js.map +1 -0
- package/modules.md +518 -106
- package/package.json +12 -3
|
@@ -0,0 +1,349 @@
|
|
|
1
|
+
# HTML Standards
|
|
2
|
+
|
|
3
|
+
## Overview
|
|
4
|
+
|
|
5
|
+
This guide provides comprehensive HTML standards focusing on semantic markup, accessibility, and document structure for modern web development.
|
|
6
|
+
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
## Semantic HTML
|
|
10
|
+
|
|
11
|
+
### Use Semantic Elements
|
|
12
|
+
|
|
13
|
+
**DO** use semantic HTML5 elements:
|
|
14
|
+
|
|
15
|
+
```html
|
|
16
|
+
<!-- ✅ GOOD: Semantic structure -->
|
|
17
|
+
<header>
|
|
18
|
+
<nav>
|
|
19
|
+
<ul>
|
|
20
|
+
<li><a href="#home">Home</a></li>
|
|
21
|
+
<li><a href="#about">About</a></li>
|
|
22
|
+
</ul>
|
|
23
|
+
</nav>
|
|
24
|
+
</header>
|
|
25
|
+
|
|
26
|
+
<main>
|
|
27
|
+
<article>
|
|
28
|
+
<h1>Article Title</h1>
|
|
29
|
+
<section>
|
|
30
|
+
<h2>Section Heading</h2>
|
|
31
|
+
<p>Content...</p>
|
|
32
|
+
</section>
|
|
33
|
+
</article>
|
|
34
|
+
|
|
35
|
+
<aside>
|
|
36
|
+
<h2>Related Links</h2>
|
|
37
|
+
<ul>...</ul>
|
|
38
|
+
</aside>
|
|
39
|
+
</main>
|
|
40
|
+
|
|
41
|
+
<footer>
|
|
42
|
+
<p>© 2026 Company Name</p>
|
|
43
|
+
</footer>
|
|
44
|
+
```
|
|
45
|
+
|
|
46
|
+
**DON'T** use generic divs when semantic elements exist:
|
|
47
|
+
|
|
48
|
+
```html
|
|
49
|
+
<!-- ❌ BAD: Non-semantic structure -->
|
|
50
|
+
<div class="header">
|
|
51
|
+
<div class="nav">...</div>
|
|
52
|
+
</div>
|
|
53
|
+
<div class="main">
|
|
54
|
+
<div class="article">...</div>
|
|
55
|
+
</div>
|
|
56
|
+
```
|
|
57
|
+
|
|
58
|
+
### Semantic Element Guidelines
|
|
59
|
+
|
|
60
|
+
- **`<header>`** - Introductory content or navigation
|
|
61
|
+
- **`<nav>`** - Navigation links
|
|
62
|
+
- **`<main>`** - Main content (one per page)
|
|
63
|
+
- **`<article>`** - Self-contained content
|
|
64
|
+
- **`<section>`** - Thematic grouping of content
|
|
65
|
+
- **`<aside>`** - Tangentially related content
|
|
66
|
+
- **`<footer>`** - Footer content
|
|
67
|
+
|
|
68
|
+
### Heading Hierarchy
|
|
69
|
+
|
|
70
|
+
**DO** maintain logical heading hierarchy:
|
|
71
|
+
|
|
72
|
+
```html
|
|
73
|
+
<!-- ✅ GOOD: Logical hierarchy -->
|
|
74
|
+
<h1>Page Title</h1>
|
|
75
|
+
<h2>Section 1</h2>
|
|
76
|
+
<h3>Subsection 1.1</h3>
|
|
77
|
+
<h3>Subsection 1.2</h3>
|
|
78
|
+
<h2>Section 2</h2>
|
|
79
|
+
```
|
|
80
|
+
|
|
81
|
+
**DON'T** skip heading levels:
|
|
82
|
+
|
|
83
|
+
```html
|
|
84
|
+
<!-- ❌ BAD: Skipped h2 -->
|
|
85
|
+
<h1>Page Title</h1>
|
|
86
|
+
<h3>Subsection</h3>
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
### Lists
|
|
90
|
+
|
|
91
|
+
Use appropriate list elements:
|
|
92
|
+
|
|
93
|
+
```html
|
|
94
|
+
<!-- Unordered list -->
|
|
95
|
+
<ul>
|
|
96
|
+
<li>Item 1</li>
|
|
97
|
+
<li>Item 2</li>
|
|
98
|
+
</ul>
|
|
99
|
+
|
|
100
|
+
<!-- Ordered list -->
|
|
101
|
+
<ol>
|
|
102
|
+
<li>Step 1</li>
|
|
103
|
+
<li>Step 2</li>
|
|
104
|
+
</ol>
|
|
105
|
+
|
|
106
|
+
<!-- Description list -->
|
|
107
|
+
<dl>
|
|
108
|
+
<dt>Term</dt>
|
|
109
|
+
<dd>Definition</dd>
|
|
110
|
+
</dl>
|
|
111
|
+
```
|
|
112
|
+
|
|
113
|
+
---
|
|
114
|
+
|
|
115
|
+
## Accessibility
|
|
116
|
+
|
|
117
|
+
### Alt Text for Images
|
|
118
|
+
|
|
119
|
+
**REQUIRED**: All images must have alt attributes:
|
|
120
|
+
|
|
121
|
+
```html
|
|
122
|
+
<!-- ✅ GOOD: Descriptive alt text -->
|
|
123
|
+
<img src="logo.png" alt="Company Logo">
|
|
124
|
+
<img src="chart.png" alt="Sales chart showing 20% growth in Q4">
|
|
125
|
+
|
|
126
|
+
<!-- Decorative images -->
|
|
127
|
+
<img src="decoration.png" alt="">
|
|
128
|
+
```
|
|
129
|
+
|
|
130
|
+
### Form Labels
|
|
131
|
+
|
|
132
|
+
**REQUIRED**: All form inputs must have associated labels:
|
|
133
|
+
|
|
134
|
+
```html
|
|
135
|
+
<!-- ✅ GOOD: Explicit label association -->
|
|
136
|
+
<label for="email">Email Address:</label>
|
|
137
|
+
<input type="email" id="email" name="email" required>
|
|
138
|
+
|
|
139
|
+
<!-- Alternative: Implicit association -->
|
|
140
|
+
<label>
|
|
141
|
+
Email Address:
|
|
142
|
+
<input type="email" name="email" required>
|
|
143
|
+
</label>
|
|
144
|
+
```
|
|
145
|
+
|
|
146
|
+
### ARIA Attributes
|
|
147
|
+
|
|
148
|
+
Use ARIA when semantic HTML is insufficient:
|
|
149
|
+
|
|
150
|
+
```html
|
|
151
|
+
<!-- Button that looks like a link -->
|
|
152
|
+
<button aria-label="Close dialog" class="close-btn">×</button>
|
|
153
|
+
|
|
154
|
+
<!-- Custom dropdown -->
|
|
155
|
+
<div role="combobox" aria-expanded="false" aria-haspopup="listbox">
|
|
156
|
+
<input type="text" aria-autocomplete="list">
|
|
157
|
+
</div>
|
|
158
|
+
|
|
159
|
+
<!-- Live region for dynamic content -->
|
|
160
|
+
<div role="status" aria-live="polite" aria-atomic="true">
|
|
161
|
+
Loading...
|
|
162
|
+
</div>
|
|
163
|
+
```
|
|
164
|
+
|
|
165
|
+
### Language and Title
|
|
166
|
+
|
|
167
|
+
**REQUIRED**: Set language and page title:
|
|
168
|
+
|
|
169
|
+
```html
|
|
170
|
+
<!DOCTYPE html>
|
|
171
|
+
<html lang="en">
|
|
172
|
+
<head>
|
|
173
|
+
<meta charset="UTF-8">
|
|
174
|
+
<title>Descriptive Page Title - Site Name</title>
|
|
175
|
+
</head>
|
|
176
|
+
```
|
|
177
|
+
|
|
178
|
+
---
|
|
179
|
+
|
|
180
|
+
## Document Structure
|
|
181
|
+
|
|
182
|
+
### Required Meta Tags
|
|
183
|
+
|
|
184
|
+
```html
|
|
185
|
+
<!DOCTYPE html>
|
|
186
|
+
<html lang="en">
|
|
187
|
+
<head>
|
|
188
|
+
<!-- Character encoding (REQUIRED) -->
|
|
189
|
+
<meta charset="UTF-8">
|
|
190
|
+
|
|
191
|
+
<!-- Viewport for responsive design (REQUIRED) -->
|
|
192
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
193
|
+
|
|
194
|
+
<!-- Page title (REQUIRED) -->
|
|
195
|
+
<title>Page Title</title>
|
|
196
|
+
|
|
197
|
+
<!-- Description (RECOMMENDED) -->
|
|
198
|
+
<meta name="description" content="Page description for SEO">
|
|
199
|
+
</head>
|
|
200
|
+
<body>
|
|
201
|
+
<!-- Content -->
|
|
202
|
+
|
|
203
|
+
<!-- Scripts at end of body or with defer/async -->
|
|
204
|
+
<script src="app.js" defer></script>
|
|
205
|
+
</body>
|
|
206
|
+
</html>
|
|
207
|
+
```
|
|
208
|
+
|
|
209
|
+
### Script Loading
|
|
210
|
+
|
|
211
|
+
**RECOMMENDED**: Place scripts before closing `</body>` tag or use `defer`/`async`:
|
|
212
|
+
|
|
213
|
+
```html
|
|
214
|
+
<!-- Option 1: Scripts at end of body -->
|
|
215
|
+
<body>
|
|
216
|
+
<!-- Content -->
|
|
217
|
+
<script src="app.js"></script>
|
|
218
|
+
</body>
|
|
219
|
+
|
|
220
|
+
<!-- Option 2: Scripts in head with defer -->
|
|
221
|
+
<head>
|
|
222
|
+
<script src="app.js" defer></script>
|
|
223
|
+
</head>
|
|
224
|
+
|
|
225
|
+
<!-- Option 3: Async for independent scripts -->
|
|
226
|
+
<head>
|
|
227
|
+
<script src="analytics.js" async></script>
|
|
228
|
+
</head>
|
|
229
|
+
```
|
|
230
|
+
|
|
231
|
+
**Differences**:
|
|
232
|
+
- **`defer`**: Downloads in parallel, executes after DOM is ready, maintains order
|
|
233
|
+
- **`async`**: Downloads in parallel, executes immediately when ready, no order guarantee
|
|
234
|
+
|
|
235
|
+
---
|
|
236
|
+
|
|
237
|
+
## Best Practices
|
|
238
|
+
|
|
239
|
+
### Use Divs and Spans Sparingly
|
|
240
|
+
|
|
241
|
+
**DO** use semantic elements first:
|
|
242
|
+
|
|
243
|
+
```html
|
|
244
|
+
<!-- ✅ GOOD -->
|
|
245
|
+
<article>
|
|
246
|
+
<h2>Title</h2>
|
|
247
|
+
<p>Content</p>
|
|
248
|
+
</article>
|
|
249
|
+
|
|
250
|
+
<!-- ❌ BAD -->
|
|
251
|
+
<div class="article">
|
|
252
|
+
<div class="title">Title</div>
|
|
253
|
+
<div class="content">Content</div>
|
|
254
|
+
</div>
|
|
255
|
+
```
|
|
256
|
+
|
|
257
|
+
**WHEN TO USE**:
|
|
258
|
+
- **`<div>`**: Generic container when no semantic element fits
|
|
259
|
+
- **`<span>`**: Inline styling or scripting hooks
|
|
260
|
+
|
|
261
|
+
### Data Attributes for JavaScript
|
|
262
|
+
|
|
263
|
+
Use `data-*` attributes for JavaScript hooks:
|
|
264
|
+
|
|
265
|
+
```html
|
|
266
|
+
<!-- ✅ GOOD: Separation of concerns -->
|
|
267
|
+
<button class="btn btn-primary" data-js-submit>Submit</button>
|
|
268
|
+
|
|
269
|
+
<script>
|
|
270
|
+
const submitBtn = document.querySelector('[data-js-submit]');
|
|
271
|
+
</script>
|
|
272
|
+
```
|
|
273
|
+
|
|
274
|
+
### Validation
|
|
275
|
+
|
|
276
|
+
**REQUIRED**: HTML must be valid:
|
|
277
|
+
|
|
278
|
+
- Use [W3C Validator](https://validator.w3.org/)
|
|
279
|
+
- Use HTMLHint or similar linting tools
|
|
280
|
+
- Close all tags properly
|
|
281
|
+
- Use lowercase for element and attribute names
|
|
282
|
+
|
|
283
|
+
---
|
|
284
|
+
|
|
285
|
+
## Common Patterns
|
|
286
|
+
|
|
287
|
+
### Navigation
|
|
288
|
+
|
|
289
|
+
```html
|
|
290
|
+
<nav aria-label="Main navigation">
|
|
291
|
+
<ul>
|
|
292
|
+
<li><a href="/" aria-current="page">Home</a></li>
|
|
293
|
+
<li><a href="/about">About</a></li>
|
|
294
|
+
<li><a href="/contact">Contact</a></li>
|
|
295
|
+
</ul>
|
|
296
|
+
</nav>
|
|
297
|
+
```
|
|
298
|
+
|
|
299
|
+
### Forms
|
|
300
|
+
|
|
301
|
+
```html
|
|
302
|
+
<form action="/submit" method="post">
|
|
303
|
+
<fieldset>
|
|
304
|
+
<legend>Personal Information</legend>
|
|
305
|
+
|
|
306
|
+
<label for="name">Name:</label>
|
|
307
|
+
<input type="text" id="name" name="name" required>
|
|
308
|
+
|
|
309
|
+
<label for="email">Email:</label>
|
|
310
|
+
<input type="email" id="email" name="email" required>
|
|
311
|
+
</fieldset>
|
|
312
|
+
|
|
313
|
+
<button type="submit">Submit</button>
|
|
314
|
+
</form>
|
|
315
|
+
```
|
|
316
|
+
|
|
317
|
+
### Tables
|
|
318
|
+
|
|
319
|
+
```html
|
|
320
|
+
<table>
|
|
321
|
+
<caption>Sales Data Q4 2026</caption>
|
|
322
|
+
<thead>
|
|
323
|
+
<tr>
|
|
324
|
+
<th scope="col">Month</th>
|
|
325
|
+
<th scope="col">Revenue</th>
|
|
326
|
+
</tr>
|
|
327
|
+
</thead>
|
|
328
|
+
<tbody>
|
|
329
|
+
<tr>
|
|
330
|
+
<td>October</td>
|
|
331
|
+
<td>$50,000</td>
|
|
332
|
+
</tr>
|
|
333
|
+
</tbody>
|
|
334
|
+
</table>
|
|
335
|
+
```
|
|
336
|
+
|
|
337
|
+
---
|
|
338
|
+
|
|
339
|
+
## Summary
|
|
340
|
+
|
|
341
|
+
**Key Principles**:
|
|
342
|
+
1. Use semantic HTML elements
|
|
343
|
+
2. Maintain logical heading hierarchy
|
|
344
|
+
3. Ensure accessibility (alt text, labels, ARIA)
|
|
345
|
+
4. Include required meta tags
|
|
346
|
+
5. Use data attributes for JavaScript hooks
|
|
347
|
+
6. Validate HTML markup
|
|
348
|
+
|
|
349
|
+
|