Introduction
What does Vue Structural Headings do?
It provides two components and optionally compoasables to help you build semantic HTML structure.
| Component | Composable |
|---|---|
| ContentContainer | useContentContainer |
| ContentHeadline | useContentHeadline |
ContentContainer
The ContentContainer is used to display the depth of the page structure.
With each nested ContentContainer, the page structure becomes one level deeper (level).
The appropriate HTML element for the page structure is determined based on the level.
ContentHeadline
The ContentHeadline is used to display the heading structure.
The ContentHeadline takes the level from the ContentContainer and sets the appropriate HTML element for the heading.
Example
vue
<template>
<div>
<header>Header</header>
<ContentContainer>
<header>
<ContentHeadline> Primary Headline (h1) </ContentHeadline>
</header>
<ContentContainer>
<ContentHeadline> Secondary Headline 1 (h2) </ContentHeadline>
<ContentContainer>
<ContentHeadline> Tertiary Headline 1.1 (h3) </ContentHeadline>
</ContentContainer>
<ContentContainer>
<ContentHeadline> Tertiary Headline 1.2 (h3) </ContentHeadline>
</ContentContainer>
</ContentContainer>
<ContentContainer>
<ContentHeadline> Secondary Headline 2 (h2) </ContentHeadline>
<ContentContainer>
<ContentHeadline> Tertiary Headline 2.1 (h3) </ContentHeadline>
<ContentContainer>
<ContentHeadline> Tertiary Headline 2.1.1 (h4) </ContentHeadline>
</ContentContainer>
</ContentContainer>
</ContentContainer>
</ContentContainer>
<footer>Footer</footer>
</div>
</template>
<script setup>
import { ContentContainer, ContentHeadline } from 'vue-semantic-structure';
</script>html
<div>
<header>Header</header>
<main>
<header>
<h1> Primary Headline (h1) </h1>
</header>
<article>
<h2> Secondary Headline 1 (h2) </h2>
<section>
<h3> Tertiary Headline 1.1 (h3) </h3>
</section>
<section>
<h3> Tertiary Headline 1.2 (h3) </h3>
</section>
</article>
<article>
<h2> Secondary Headline 2 (h2) </h2>
<section>
<h3> Tertiary Headline 2.1 (h3) </h3>
<article>
<h4> Tertiary Headline 2.1.1 (h4) </h4>
</article>
</section>
</article>
</main>
<footer>Footer</footer>
</div>