Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
vue-intersect
Advanced tools
A Vue component to add intersection-observer to a Vue component or HTML element.
A Vue component to add intersection-observer to a Vue component or HTML element.
The IntersectionObserver is an amazing API which allows you to observe one or more HTMLElement for when it has entered or left the viewport.
This API has many use cases like, infinite-scroll, lazy-loading or animations when an element enters the viewport.
We've made a basic demo of how you might want to use vue-intersect. The code is available in the gh-pages branch and the part where vue-intersect is used can be found here.
Hackernews infinite scroll demo
Please keep in mind that the demo is not production code. Use it as an inspiration.
Simply install using your favorite package manager 🔥
npm install vue-intersect --save
yarn add vue-intersect
The package acts as an abstract component, much like what you may know from keep-alive or transition.
This means that it's basically a "decorator". A component which does not output any markup to the DOM, but adds the functionality under the hood 😱.
<template>
<intersect @enter="msg = 'Intersected'" @leave="msg = 'Not intersected'">
<div>{{ msg }}</div>
</intersect>
</template>
<script>
import Intersect from 'vue-intersect'
export default {
components: { Intersect },
data () {
return {
msg: 'I will change'
}
}
}
</script>
Property | Type | Default | Required | Description |
---|---|---|---|---|
threshold | Array | [0, 0.2] | no | MDN docs |
root | HTMLElement | null | no | MDN docs |
rootMargin | String | 0px 0px 0px 0px | no | MDN docs |
Name | Arguments | Description |
---|---|---|
change | IntersectionObserverEntry | Event fired on any inte. |
enter | IntersectionObserverEntry | Event fired when the element is intersected (visible on the screen) |
leave | IntersectionObserverEntry | Event fired when the element is not intersected (not visible on the screen) |
destroyed | None | Fired when the underlying element is destroyed |
The enter and leave event is sugar, for an often performed operation. You still have to set the threshold to e.g. [0, 0.2] (default). If you leave out "0", it will never call the leave event.
The events is compliant with Vue's event modifiers. This means that you could add .once
to the events to make sure you only trigger your event handler once.
The IntersectionObserver API is not currently available in all browsers (IE11, Safari and iOS Safari). If you intend to support these browsers, you'll need to add a poylfill to your bundle.
WICG IntersectionObserver Polyfill is highly recommended.
FAQs
A Vue component to add intersection-observer to a Vue component or HTML element.
The npm package vue-intersect receives a total of 4,424 weekly downloads. As such, vue-intersect popularity was classified as popular.
We found that vue-intersect demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
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.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.