npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

sticky-menu

v1.2.10

Published

A light-weight sticky navigation plugin written in vanilla javascript.

Downloads

15

Readme

sticky-menu

sticky-menu is a light-weight plugin to easily create a sticky navigation which can be customized for your needs. It's written in vanilla javascript and comes without any further dependencies.

Installation

npm install sticky-menu

Usage

First, make sure to import dependency:

import StickyMenu from 'sticky-menu';

Import basic css:

@import '~/stickymenu/css/style.css'; /* you may check if you need the tilde (~) alias for /node_modules folder. */

Setup

Setup requires an element HTMLElement. Options are passed as Object.

const sticky = new StickyMenu(options);

Requires an html element selector (classname, id, data-attribute, …). Options are passed as Object.

Basically you need:

const options = {
  // place options here
};
const stickyMenu = new StickyMenu(options); // fires init

Example with options:

const menuElementSelector = document.querySelector('.myNavElement');
const stickyMenu = new StickyMenu({
  menuElement: menuElementSelector,
  contentElement: document.querySelector('main'), 
  contentElementOffset: 100,  // content offset (in px)
  startStickyAtPos: 30,       // sticky menu starts if scrollTop is >= 30px
  resizeEventTimeout: 100,    // timeout after which the resize event fires (in ms)
  scrollEventTimeout: 100,     // timeout after scroll the scroll event fires (in ms)
});

stickyMenu.init(); // call init() to fire plugin

Options

| Option name | Type | Default | Description | Required | |---|---|---|---|---| | breakpoint | Number | 0 (in px) | Stickymenu is only initialized if window width is above or equal to breakpoint. | false | | contentElement | HTMLElement || Element to apply offset (in px) on.Note: a (sticky) element with position: fixed usually causes 'jumping' content due to its missing height.To prevent that, just use the contentElementOffset option by adding offset to the to the next following element after your menu element. Will only be applied if option is set. | false | | contentElementOffset | Number | 0 (in px) | Sets content element offset. | false | | menuElement | HTMLElement | | The target element to apply sticky mode on. | true | | menuClass | String | stickymenu | A css class which is added to target element when in sticky mode.Note: the active class is generated automatically. yourClassName results in yourclassname-active. | false | | scrollPosY | Number | 0 (in px) | Controls at which scroll position the stickymenu takes effect. | false | | resizeEventTimeout | Number | 50 (in ms) | Final event execution in resize handler is delayed to prevent being fired on every px while resizing.This sets timeout in ms after which the final resize event fires. | false | | scrollEventTimeout | Number | 50 (in ms) | Final event execution in scroll handler is delayed to prevent being fired on every px while scrolling.This sets timeout in ms after which the final scroll event fires. | false |