Hide your header and footer until you need it!
Svelte Headroom is a Svelte component to hide or show your header and footer on scroll, adapted from collardeau/svelte-headroom, inspired by headroom.js.
@taocode/svelte-headroom
has no dependencies.
Get the source from the GitHub repository (@taocode/svelte-headroom) and play with it directly. Run pnpm dev
(or yarn, npm equivalents) and edit the demo test page: src/routes/+page.svelte
One of these:
pnpm install -D @taocode/svelte-headroom
yarn add -D @taocode/svelte-headroom
npm install -D @taocode/svelte-headroom
<script>
import Headroom from '@taocode/svelte-headroom';
</script>
<Headroom>
<!-- Header will be fixed at top
and auto show/hide based on scroll -->
</Headroom>
The number of pixels that need to be scrolled in either direction for the effect to occur. This is useful if you want the user to be able to scroll slowly and not change the header position.
default: 0
-- Overridden by toleranceDown
and toleranceUp
<Headroom tolerance={10}>
<!-- ignore any scroll less than 10px -->
</Headroom>
The number of pixels that need to be scrolled down for the effect to occur. This is useful if you want the user to be able to scroll slowly but respond differently to the downward direction.
default: tolerance
-- Overrides tolerance
<Headroom toleranceDown={10}>
<!-- ignore downward scroll less than 10px -->
</Headroom>
The number of pixels that need to be scrolled up for the effect to occur. This is useful if you want the user to be able to scroll slowly but respond differently in the upward direction.
default: tolerance
-- Overrides tolerance
<Headroom toleranceUp={10}>
<!-- ignore upward scroll less than 10px -->
</Headroom>
The number of pixels from the top or bottom of the page before the effect is allowed to occur; controls: class:atTop
and class:atBottom
(useful with (show|hide)At(Bottom|Top)).
default: 2
-- Overridden by offsetTop
and offsetBottom
The number of pixels from the top of the page before the effect is allowed to occur; controls: class:atTop
(useful with hideAtTop, showAtTop).
default: offset
-- Overrides offset
<Headroom offsetTop={50}>
<!-- will show until after 50px from top -->
</Headroom>
The number of pixels from bottom to be considered at the bottom; controls class:atBottom
(useful with hideAtBottom, showAtBottom).
default: offset
-- Overrides offset
<Headroom showAtBottom offsetBottom={150}>
<!-- show when within 150px of bottom -->
</Headroom>
The duration of the sliding effect. The value is passed on as a CSS Transition Duration.
default: "300ms"
<Headroom duration='500ms'>
<!-- take 500ms to transition -->
</Headroom>
The timing function (easing) of the sliding effect. The value is passed on as a CSS Transition Timing Function.
default: "linear"
<Headroom easing='ease-out'>
<!-- will ease-out -->
</Headroom>
If this is to be pinned to the bottom, like a return to top button.
default: false
Note: you'll need to wrap a bottom pinned Headroom to use it because it isn't 100% wide to avoid covering links and breaking the UI a bit. You can play with heights and widths and different positioning; see below for my favorite .totop-wrap
<div class="totop-wrap">
<Headroom bottom>
<!-- pinned to the bottom -->
</Headroom>
</div>
If this is to be pinned to the bottom, like a return to top button.
default: false
Note: atBottom detection fails on Svelte REPL.
<Headroom showAtBottom>
<!-- always show when at bottom -->
</Headroom>
<div class="totop-wrap">
<Headroom
bottom hideAtTop showAtBottom
toleranceUp={20} offset={50}>
<!-- footer for 'to top' button -->
<button
class="totop"
on:click={()=> window.scroll(0,0)}
>
<span class="caret">^</span>
<span>To Top</span>
</button>
</Headroom>
</div>
<style>
.totop-wrap {
max-width: 90ch;
margin: 0 auto;
display: flex;
justify-content: end;
}
.totop {
margin: 2em;
background: hsl(29, 100%, 40%);
color: white;
border: 0;
padding: 0.5rem;
cursor: pointer;
display: flex;
flex-direction: column;
align-items: center;
text-transform: uppercase;
font-size: 0.667em;
line-height: 1.5rem;
}
.caret {
font-size: 4em;
padding-top: 0.6rem;
}
</style>
A svelte-headroom
component emits two events: pin
and unpin
.
<Headroom
on:pin={ () => {} }
on:unpin={ () => {} }
>
<header>My Header</header>
</Headroom>