Skip to content

tarqd/scrollspy

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Scroll Spy Component

Listen for scroll events on a window, document, or element and execute callbacks when child elements scroll in or out of view (see example/example.html)

Installation

Install with component(1):

$ component install ilsken/scrollspy

Example

// Make the navigation bar stick to the top of the page when the user scrolls past it
var nav = document.getElementById("nav")
var spy = require('scrollspy')(window)
spy
  .enter(setClass('fixed'))
  .leave(setClass(''))
  .start()
  .add(nav) // default listens for topOffset: 0 (reaches top of the target element or window)

function setClass(value) {
  return function () {
    this.setAttribute('class', value);
  }
}

API

ScrollSpy()

@param {HTMLElement} element
@return {ScrollSpy}

exports.prototype.start()

Start listening for scroll events

@return {ScrollySpy} self for chaining

exports.prototype.stop()

Stop listening for scroll events

@return {ScrollSpy} self for chaining

exports.prototype.add()

Add ScrollHandler for an element.

@param {HTMLElement} element Element you want to react to scroll events
@param {Number} topOffset Offset from top to trigger the enter event (default is 0)
@param {Number} leftOffset Offset from the left that you wish to trigger the enter event (default is undefined (ignore left offset))
@return {ScrollHandler} Handler object

exports.prototype.remove()

Remove a scroll handler.

You can either pass the ScrollHandler returned by ScrollSpy#add or an HTMLElement If you pass an HTML element all listeners for that element will be removed If you pass a top or left offset, only listeners matching that element and offset will be removed

@param {ScrollHandler|HTMLElement} element Scroll handler to remove or an HTMLElement
@param {Remove} by topOffset} topOffset Remove by top offset
@param {Number} leftOffset Remove by left offset
@return {ScrollSpy} self for chaining

exports.prototype.enter

Set a default enter handler

Called when an element has scrolled into the location specified by either of it's offsets Must be in the form of function handler(is_at_top_offset, is_at_left_offset).

@param {Function} handler
@return {ScrollSpy} self for chaining

exports.prototype.leave

Set a default leave handler

Called when an element has left the location specified by either of it's offsets Must be in the form of function handler(is_at_top_offset, is_at_left_offset).

@param {Function} handler
@return {ScrollSpy} self for chaining

ScrollHandler()

ScrollHandler

@param {ScrollSpy} spy
@param {HTMLElement} element
@param {Number} topOffset
@param {Number} leftOffset

ScrollHandler.prototype.offset()

Gets or sets the offset for this handler

@param {Number} topOffset
@param {Number} leftOffset
@return {ScrollHandler} self for chaining

ScrollHandler.prototype.end()

Gets the parent ScrollSpy instance

@return {ScrollSpy} parent ScrollSpy instance

Handler.prototype.enter

Set the enter handler

Called when an element has scrolled into the location specified by either of it's offsets Must be in the form of function handler(is_at_top_offset, is_at_left_offset).

@param {Function} handler
@return {ScrollSpy} self for chaining

ScrollHandler.prototype.leave

Set the leave handler

Called when an element has left the location specified by either of it's offsets Must be in the form of function handler(is_at_top_offset, is_at_left_offset).

@param {Function} handler
@return {ScrollSpy} self for chaining

License

MIT

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published