intersection-events
Wrapper of IntersectionObserver
You can detect when the whole element enters and leaves window.
Installation
ES Modules
npm
npm i intersection-events
import IntersectionEvents from 'intersection-events'
CDN
unpkg
<script src="https://unpkg.com/intersection-events"></script>
Usage
Docs
new IntersectionEvents('.js-target', {
onEnter: el => {
},
onLeave: el => {
}
})
<div class="js-target"></div>
<div class="js-target" data-enter-threshold="0.5" data-leave-threshold="0.5"></div>
If you want to detect enter only once, set isOnce
option to true
.
new IntersectionEvents('.js-target', {
onEnter: el => {
},
isOnce: true
})
Browsers support
data:image/s3,"s3://crabby-images/11c84/11c84fc453d141f24ffbe72b21633a17c4afaf46" alt="Edge" Edge | data:image/s3,"s3://crabby-images/c8172/c8172b98431b7dc09d5a8465633e251876805972" alt="Firefox" Firefox | data:image/s3,"s3://crabby-images/47c71/47c71fc9d1edf1bc0dc97bf0c0708fd99c5e977a" alt="Chrome" Chrome |
---|
Edge | last version | last version |
Note
If you need to support browsers that do not support IntersectionObserver
, load the IntersectionObserver
polyfill.
If the IntersectionObserver
polyfill is loaded, browsers support is as follows.
data:image/s3,"s3://crabby-images/11c84/11c84fc453d141f24ffbe72b21633a17c4afaf46" alt="IE / Edge" IE / Edge | data:image/s3,"s3://crabby-images/c8172/c8172b98431b7dc09d5a8465633e251876805972" alt="Firefox" Firefox | data:image/s3,"s3://crabby-images/47c71/47c71fc9d1edf1bc0dc97bf0c0708fd99c5e977a" alt="Chrome" Chrome | data:image/s3,"s3://crabby-images/f2149/f21499c81fa77689d7b9a448b272bd2e468e7ec2" alt="Safari" Safari | data:image/s3,"s3://crabby-images/64752/64752f22943b08fe769b87f5857f187b29a84330" alt="iOS Safari" iOS Safari |
---|
IE11, Edge | last version | last version | last version | last version |
If you want more features, please consider other libraries.