
Research
Security News
The Landscape of Malicious Open Source Packages: 2025 Mid‑Year Threat Report
A look at the top trends in how threat actors are weaponizing open source packages to deliver malware and persist across the software supply chain.
scrollmirror
Advanced tools
Install the plugin from npm and import it into your bundle:
npm i scrollmirror
import ScrollMirror from "scrollmirror";
Or include the minified production file from a CDN:
<script src="https://unpkg.com/scrollmirror"></script>
Suppose you have the following HTML:
<div class="scrollers">
<div class="scroller">
<!-- some HTML that forces the element to have overflow -->
</div>
<div class="scroller">
<!-- some HTML that forces the element to have overflow. Different length than the previous .scroller -->
</div>
</div>
<style>
.scrollers {
display: grid;
grid-template-columns: 50% 50%;
width: 500px;
}
.scroller {
height: 200px;
overflow: auto; /* this is important! */
}
</style>
This is how you would mirror the scroll position between the two div.scroller
:
import ScrollMirror from "scrollmirror";
/** Mirror all divs that match the class `.scroller` */
new ScrollMirror(document.querySelectorAll(".scroller"));
See also this minimal example on CodePen
💡 To mirror the scroll position from and to the window
, you would have to add one of :root
, html
or body
to the selector:
new ScrollMirror(document.querySelectorAll(":root, .scroller"));
/** or */
new ScrollMirror(document.querySelectorAll("html, .scroller"));
/** or */
new ScrollMirror(document.querySelectorAll("body, .scroller"));
You can pass in a few additional options to ScrollMirror as the second argument:
new ScrollMirror(document.querySelectorAll(".scroller"), options);
The type signature of the options object:
type Options = {
vertical: boolean;
horizontal: boolean;
debug: boolean;
}
vertical
Type: boolean
, default: true
. Should the vertical scroll position be mirrored?
horizontal
Type: boolean
, default: true
. Should the horizontal scroll position be mirrored?
debug
Type: boolean
, default: true
. Should debug messages be printed to the console?
To access ScrollMirror's API, you have to save a reference to the class during instaciation:
const mirror = new ScrollMirror(document.querySelectorAll(".scroller"));
mirror.progress
Get the current scroll progress in the form of { x: number, y: number }
, where both x and y are a
number between 0-1
mirror.progress = value
Set the progress and scrolls all mirrored elements. For example:
// for both directions
mirror.progress = { x: 0.2, y: 0.5 };
// or only set one direction
mirror.progress = { y: 0.5 };
// or for both directions at once:
mirror.progress = 0.5;
mirror.getScrollProgress(element: HTMLElement)
Get the current progress of an element. The element doesn't need to be one of the mirrored elements
const mirror = new ScrollMirror(document.querySelectorAll(".scroller"));
// ...sometime later:
console.log(mirror.getScrollProgress(document.querySelector(":root")));
There are already a few libraries out there that do the same thing. But all I could find had some limitations (For example, react-scroll-sync needs React, syncscroll doesn't provide an NPM package).
Also, this simple package gave me an excuse to play around with the tooling involved with creating a robust open source npm
package:
1.2.1
@changesets/cli
for managing releases and the CHANGELOG.mddevEngines.packageManager
instead of npx only-allow pnpm
for enforcing pnpm
as a the manager (thanks @bjoerge)FAQs
Sync the scroll position of multiple elements on your page
The npm package scrollmirror receives a total of 84,810 weekly downloads. As such, scrollmirror popularity was classified as popular.
We found that scrollmirror demonstrated a healthy version release cadence and project activity because the last version was released less than 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.
Research
Security News
A look at the top trends in how threat actors are weaponizing open source packages to deliver malware and persist across the software supply chain.
Security News
ESLint now supports HTML linting with 48 new rules, expanding its language plugin system to cover more of the modern web development stack.
Security News
CISA is discontinuing official RSS support for KEV and cybersecurity alerts, shifting updates to email and social media, disrupting automation workflows.