AgentSkillsCN

html-basics

核心HTML5元素、文档结构和基础标记模式

SKILL.md
--- frontmatter
name: html-basics
description: Core HTML5 elements, document structure, and foundational markup patterns
sasmp_version: "1.3.0"
bonded_agent: html-expert
bond_type: PRIMARY_BOND
version: "2.0.0"

# Skill Metadata
category: markup
complexity: foundational
dependencies: []

# Parameter Validation
parameters:
  element_type:
    type: string
    required: true
    enum: [document, text, grouping, embedded, interactive, metadata]
  output_format:
    type: string
    default: "html"
    enum: [html, jsx, template]
  include_comments:
    type: boolean
    default: false

# Retry Configuration
retry:
  max_attempts: 3
  backoff_ms: [1000, 2000, 4000]
  retryable_errors: [NETWORK_ERROR, TIMEOUT]

HTML Basics Skill

Core HTML5 elements and document structure patterns for production web development.

🎯 Purpose

Provide atomic, single-responsibility operations for:

  • Document structure creation (<!DOCTYPE>, <html>, <head>, <body>)
  • Text content elements (<p>, <h1>-<h6>, <blockquote>)
  • Grouping content (<div>, <main>, <section>)
  • Embedded content (<img>, <iframe>, <video>)
  • Metadata elements (<meta>, <link>, <title>)

📥 Input Schema

typescript
interface HtmlBasicsInput {
  operation: 'create' | 'validate' | 'convert' | 'explain';
  element_type: ElementCategory;
  content?: string;
  attributes?: Record<string, string>;
  options?: {
    doctype?: 'html5' | 'xhtml';
    lang?: string;           // Default: 'en'
    charset?: string;        // Default: 'UTF-8'
  };
}

type ElementCategory =
  | 'document'    // html, head, body, doctype
  | 'text'        // p, h1-h6, span, strong, em
  | 'grouping'    // div, main, section, article
  | 'embedded'    // img, video, audio, iframe
  | 'interactive' // a, button, details
  | 'metadata';   // meta, link, title, base

📤 Output Schema

typescript
interface HtmlBasicsOutput {
  success: boolean;
  markup: string;
  validation: {
    valid: boolean;
    errors: string[];
    warnings: string[];
  };
  metadata?: {
    element_count: number;
    nesting_depth: number;
    has_required_attrs: boolean;
  };
}

🛠️ Core Operations

1. Document Structure

html
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Page Title</title>
</head>
<body>
  <!-- Content here -->
</body>
</html>

Required Elements Checklist:

  • <!DOCTYPE html> declaration
  • <html lang="..."> with language attribute
  • <meta charset="UTF-8">
  • <meta name="viewport"> for responsive design
  • <title> element (60 chars max for SEO)

2. Text Content Elements

ElementPurposeExample
<h1>-<h6>Headings (one h1 per page)<h1>Main Title</h1>
<p>Paragraph text<p>Content...</p>
<strong>Strong importance<strong>Important</strong>
<em>Stress emphasis<em>emphasized</em>
<mark>Highlighted text<mark>highlighted</mark>
<blockquote>Extended quotation<blockquote cite="...">
<code>Code snippet<code>console.log()</code>
<pre>Preformatted text<pre> formatted </pre>

3. Grouping Elements

ElementPurposeWhen to Use
<div>Generic containerNo semantic meaning needed
<main>Primary contentOnce per page, unique content
<section>Thematic groupingWith heading, related content
<article>Self-containedBlog post, news article
<aside>Tangential contentSidebars, callouts

4. Embedded Content

html
<!-- Image with required attributes -->
<img src="photo.jpg" alt="Description" width="800" height="600" loading="lazy">

<!-- Responsive image -->
<picture>
  <source media="(min-width: 800px)" srcset="large.jpg">
  <source media="(min-width: 400px)" srcset="medium.jpg">
  <img src="small.jpg" alt="Description">
</picture>

<!-- Video with fallback -->
<video controls width="640" height="360">
  <source src="video.mp4" type="video/mp4">
  <source src="video.webm" type="video/webm">
  <p>Your browser doesn't support video.</p>
</video>

⚠️ Error Handling

Validation Errors

Error CodeDescriptionAuto-Fix
HB001Missing DOCTYPEAdd <!DOCTYPE html>
HB002Missing lang attributeAdd lang="en"
HB003Missing charsetAdd <meta charset="UTF-8">
HB004Missing alt on imgPrompt for alt text
HB005Empty headingFlag for content
HB006Invalid nestingRestructure elements

Recovery Procedures

code
Error Detected → Log Issue → Attempt Auto-Fix → Validate → Report
        ↓
   [If unfixable]
        ↓
   Return error with suggestion

🔍 Troubleshooting

Problem: Page not rendering correctly

code
Debug Checklist:
□ DOCTYPE present and first line?
□ HTML tag has lang attribute?
□ Head contains charset meta?
□ All tags properly closed?
□ No duplicate IDs?
□ Valid nesting structure?

Problem: Images not loading

code
Debug Checklist:
□ File path correct (relative/absolute)?
□ File exists at location?
□ Correct file extension?
□ Server MIME types configured?
□ Alt attribute present?

Problem: Content not accessible

code
Debug Checklist:
□ Heading hierarchy correct?
□ Landmarks present (main, nav)?
□ Images have alt text?
□ Links have descriptive text?
□ Language attribute set?

📊 Quality Metrics

MetricTargetTool
Valid HTML0 errorsW3C Validator
Nesting depth≤6 levelshtml-validate
Required attrs100%Custom linter
Semantic ratio>70%Manual audit

📋 Usage Examples

yaml
# Create document structure
skill: html-basics
operation: create
element_type: document
options:
  lang: "en"
  charset: "UTF-8"

# Validate existing markup
skill: html-basics
operation: validate
content: "<div><p>Test</div></p>"  # Will catch nesting error

# Convert to JSX
skill: html-basics
operation: convert
element_type: text
content: "<p class='intro'>Hello</p>"
output_format: jsx  # Returns: <p className="intro">Hello</p>

🔗 References