Socket
Book a DemoInstallSign in
Socket

@codingheads/sticky-header

Package Overview
Dependencies
Maintainers
2
Versions
3
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@codingheads/sticky-header

A library that allows you to create sticky headers. It uses `position: sticky` and IntersectionObserver

1.0.2
latest
Source
npmnpm
Version published
Weekly downloads
952
-80.81%
Maintainers
2
Weekly downloads
 
Created
Source

Sticky Header

This library allows you to create sticky headers. It uses position: sticky and IntersectionObserver.

The plugin doesn't require jQuery, but it adds itself to jQuery if jQuery exists on the page.

Installing

Use npm (or yarn) to install the package.

npm install --save @codingheads/sticky-header

Initializing in JavaScript

To initialize the library, you need to create a new instance of the StickyHeader class:

import StickyHeader from '@codingheads/sticky-header';

const header = document.querySelector('header.page-header');
new StickyHeader(header, options);

Or using jQuery:

import '@codingheads/sticky-header';

$('header.page-header).stickyHeader(options);

The options object can have the following properties:

  • mainClass - the class added when the plugin is initialized (default: sticky)
  • pinnedClass - the class added when the element becomes "stuck" (default: sticky-pinned)
  • unpinnedClass - the class added when the element becomes "unstuck" (default: sticky-unpinned)
  • offset - the offset (in pixels) where the element should become "stuck" (default: 0)
  • addBodyClasses - add the pinnedClass and unpinnedClass classes to the body element as well (default: true)

Warnings

  • The plugin uses position: sticky. This is supported in all modern browsers. However, position: sticky has some requirements: you must not have parent elements with overflow: hidden, or otherwise it will not work (the position will be static). If you cannot get it to start, check that you don't have overflow: hidden on a parent element.

  • If you change the header size depending on the "stuck"/"unstuck" status, you will probably need to prevent the window from scrolling when this happens (the header will push the content).

If you have a #wrapper element around the content (including the header), you could do something like this:

header.sticky {
  top: 0;
  position: sticky;
}

/** fix for when the header grows in size when it becomes unpinned and the scroll position changes (we need to scroll more) **/
@supports (position: sticky) {
  body.sticky-unpinned #wrapper {
    overflow-anchor: none;
  }
}

Keywords

sticky

FAQs

Package last updated on 10 Jul 2021

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

About

Packages

Stay in touch

Get open source security insights delivered straight into your inbox.

  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc

U.S. Patent No. 12,346,443 & 12,314,394. Other pending.