Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

intersection-observer-polyfill

Package Overview
Dependencies
Maintainers
1
Versions
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

intersection-observer-polyfill

A polyfill of IntersectionObserver API

  • 0.1.0
  • latest
  • Source
  • npm
  • Socket score

Version published
Maintainers
1
Created
Source

IntersectionObserver Polyfill

A polyfill of IntersectionObserver API.

Implements event based tracking of changes in elements position. Uses MutationsObserver and falls back to an infinite dirty checking cycle if the first one is not supported. Handles long running CSS transitions/animations, attributes and nodes mutations along with changes made by :hover pseudo-class (optional).

Written in ES6 and compliant with the spec and native implementation. Doesn't contain any publicly available methods or properties except for those described in spec. Size is 4kb when minified and gzipped.

Live demo (won't run in IE9).

Installation

From NPM:

npm install --save intersection-observer-polyfill

From Bower:

bower install --save intersection-observer-polyfill

Or just grab one of the pre-built versions from dist.

Browser Support

Polyfill has been tested and known to work in the following browsers:

  • Firefox 31+
  • Edge 13+
  • Internet Explorer 11
  • Internet Explorer 9-10 (tested in compatibility mode of IE11)
  • Chrome 40+ (native support since 51)
  • Opera 30+ (native support since 38)
  • Safari was not tested but expected to work

Usage Examples

If you are using ES6 modules with bundlers like Webpack or JSPM:

import IntersectionObserver from 'intersection-observer-polyfill';

const observer = new IntersectionObserver((entries, observer) => {}, {
    rootMargin: '100px 0px',
    threshold: [0, 0.1, 0.2, 0.5, 1]
});

// ...

Alternatively you can take a pre-built UMD version.

With AMD:

define([
    'intersection-observer-polyfill/dist/IntersectionObserver'
], function (IntersectionObserver) {
    // ...
});

With CommonJS:

var IntersectionObserver = require('intersection-observer-polyfill/dist/IntersectionObserver');

As browsers' global:

<script src="intersection-observer-polyfill/dist/IntersectionObserver.js"></script>
<script>
    (function () {
        var observer = new IntersectionObserver(function () {});
    })();
</script>

Global exports

Optionally you can take a version that always exports itself globally.

With ES6 modules:

import 'intersecton-observer-polyfill/index.global';

const observer = new IntersectionObserver(() => {});

With AMD/CommonJS:

require('intersecton-observer-polyfill/dist/IntersectionObserver.global');

Configuration

IntersectionObserver class additionally implements following static accessor properties:

idleTimeot

When DOM elements change theirs attributes like class or style an update cycle will be initiated. This cycle is used to catch possible CSS transitions/animations and the idleTimeout tells for how long we need run it if it doesn't detect any changes in elements position.

Default value is 50 milliseconds and you can increase it to match the delay of transitions, e.g. if transition starts after 500 milliseconds then you can set idleTimeout to the corresponding value: IntersectionObserver.idleTimeout = 500;. If you don't plan to use transitions then you can set this value to 0. Otherwise it's safer to leave the default value, even if transition starts immediately.

trackHovers

By default possible changes in position of elements caused by CSS :hover class are not tracked. You can set IntersectionObserver.trackHovers = true if you need them to be supported.

NOTE: Changes made to these properties will affect all instances of IntersectionObserver, even those that were already created.

Acknowledgments

I'm very grateful to Philip Walton for the test suites of observe/unobserve methods that I took from his implementation.

Keywords

FAQs

Package last updated on 05 Jul 2016

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

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc