web-blog/node_modules/@zachleat/heading-anchors/README.md

55 lines
2.3 KiB
Markdown
Raw Permalink Normal View History

2026-05-29 18:34:34 +00:00
# `<heading-anchors>` Web Component
A web component to add and position sibling anchor links for heading elements (`h1``h6`) when they have an `id` attribute.
Inspired by [David Darnes `<heading-anchors>`](https://github.com/daviddarnes/heading-anchors).
* [Demo](https://zachleat.github.io/heading-anchors/demo.html) on GitHub Pages
## Installation
```
npm install @zachleat/heading-anchors
```
Include the `heading-anchors.js` file on your web site (via `<script type="module">`) and use `<heading-anchors>`.
## Features
* Useful when you want preserve heading text as is (selectable, able to nest other links, etc).
* Useful when you want to exclude anchor links from your RSS feed.
* Links are positioned alongside heading text, but _not_ nested inside of headings (for improved screen-reader compatibility and accessibility)
* Establishes a placeholder element to establish space for the anchor link and so that heading text doesnt reflow during interaction
* Prefers the CSS Anchoring API (where available) but works using JavaScript positioning when the API is not available.
* Automatically matches `font` styling of the heading (`font-family`, `line-height`, `font-size`, and `font-weight`)
### Options
* Use the `selector` attribute to change the headings used, e.g. `<heading-anchors selector="h2,h3,h4">`
* Default: `h2,h3,h4,h5,h6`
* Internationalization (i18n) friendly using the `prefix` attribute to change the accessible text inside the anchor links, e.g. `<heading-anchors prefix="Ir a la sección titulada">`
* Default: `Jump to section titled`
* Use the `content` attribute to change the character used.
* Default: `#`, supports an empty string if you want to use CSS pseudo elements.
* Style the anchor link using `.ha-placeholder` selector (change font-family, etc).
* Use the `data-ha-exclude` attribute to opt-out of an anchor link.
### Prior Art
* https://github.com/daviddarnes/heading-anchors
* https://amberwilson.co.uk/blog/are-your-anchor-links-accessible/ (which has a lot of good related content too)
## Advanced
### Eliminate Layout Shift
(Optional) There is a small layout shift by the addition of the `#` character. Add this CSS to make room for this pre-component definition:
```css
heading-anchors:not(:defined) :is(h2,h3,h4,h5,h6):after {
content: "#";
padding: 0 .25em;
opacity: 0;
}
```