Skip to main content

HTML Guide

Stray start tag “section”.

The “Stray start tag “section”” error in the W3C HTML Validator typically occurs when a <section> tag appears in an unexpected location within your HTML document structure. This can happen if the <section> tag is not positioned correctly within the HTML5 content model.

Here’s a focused guide to fix this issue:

1. Check the Parent Element

Make sure the <section> tag is placed within elements where it is allowed. According to the HTML5 specification:

  • A <section> element should be placed within the <body> tag.
  • It should not be a direct child of an inline element or an element that does not support flow content.

2. Correct Nesting Within Elements

Ensure your HTML structure follows a logical hierarchy and that the <section> element is not incorrectly nested. This example shows a correct usage of the <section> tag:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Correct Usage of Section</title>
</head>
<body>
    <header>
        <h1>Page Title</h1>
    </header>
    
    <nav>
        <!-- Navigation links -->
    </nav>
    
    <main>
        <section>
            <h2>Section Title</h2>
            <p>Content for the first section.</p>
        </section>
        
        <section>
            <h2>Another Section Title</h2>
            <p>Content for the second section.</p>
        </section>
    </main>
    
    <footer>
        <p>Footer content</p>
    </footer>
</body>
</html>

3. Check for Mistaken Hierarchy

Verify whether the <section> tag is mistakenly placed inside elements that do not support it, such as directly inside a <p> tag or other inline elements. Correct any incorrect usage. For example this is incorrect usage because the <section> tag is placed after the closing <body> tag:

Incorrect:

<!DOCTYPE html>
<html lang="en">
<head>
    <title>Sample page</title>
</head>
<body>
  <h1>Main title</h1>
  <p>Some content</p>
</body>
</html>

<section>
  <h2>Incorrect Section</h2>
  <p>This section should not be after the closing body tag.</p>
</section>

Correct:

<!DOCTYPE html>
<html lang="en">
<head>
    <title>Sample page</title>
</head>
<body>
  <h1>Main title</h1>
  <p>Some content</p>

  <section>
    <h2>Correct Section</h2>
    <p>This section is fine.</p>
  </section>
</body>
</html>

Summary

  1. Ensure your <section> tags are used within the <body> tag and other allowed elements.
  2. Maintain a logical hierarchy in your HTML document.
  3. Avoid placing <section> tags inside inline elements like <p>.

Following these steps should resolve the “Stray start tag “section”” error in your HTML document. Validate your HTML again after making these corrections to ensure the issue is resolved.

Related W3C validator issues