Copied!
It's on your clipboard.
You’ve been offline for 0 second. Please check your Internet connection.

Help Us Improve

Found an issue or have an idea? Let us know.
Select all that apply...
Thank you! Your submission has been received!
Oops! Something went wrong while submitting the form.
Lenis Scroll-To Anchor
Preview
Download Template
Report Bug

Info

Resource
Scroll
Builder
Elementor
Add-ons
Elementor Pro
Last Updated
Jan 2, 2026

Overview

This script smooths anchor navigation with Lenis, turning abrupt jumps into fluid, controlled scroll transitions that feel deliberate and refined.

Features

Setup

01
Add External Scripts

Copy & paste the scripts before the </body> tag of your project. If you added them before for another setup, skip this step.

Language
Copy
01
Copy structure to Elementor

Right-click in Elementor, choose “Paste from another site,” and while the popup is open, press cmd/ctrl + v to insert the layout.

Copy To Elementor
01
Add HTML

Place the code in an HTML widget or add it through Elementor → Custom Code (before the closing </body> tag) either globally or only on selected pages.

Language
Copy
01
Add custom CSS

Paste the code through the page or site settings, or add it via Elementor → Custom Code (before </body>) for broader use.

Language
Copy
01
Add custom Javascript

Paste the script through Elementor → Custom Code (set to load after </body>) for site-wide or page-specific loading.

Language
Copy
document.addEventListener("DOMContentLoaded", () => {

  if (document.body.classList.contains("elementor-editor-active")) return;

  const lenis = window.ouLenis;
  if (!lenis) return;

  // Anchor scroll duration
  const anchorDuration = 1.2;

  // Anchor offset from top
  const anchorOffset = 0;

  document.addEventListener("click", e => {
    const link = e.target.closest('a[href^="#"]');
    if (!link) return;

    const href = link.getAttribute("href");
    if (href === "#" || !href.startsWith("#")) return;

    const target = document.querySelector(href);
    if (!target) return;

    e.preventDefault();

    lenis.scrollTo(target, {
      duration: anchorDuration,
      offset: anchorOffset,
      easing: t => 1 - Math.pow(1 - t, 3)
    });
  });

});
01
Add custom PHP

Place the PHP snippet inside your theme’s functions.php or using any code snippet to enable logic.

Language
Copy
01
01
Publish and preview live
Some solutions only work on the live site. Always publish and test after each change, as results may not appear in the editor.

Implementation

These options control how anchor scrolling behaves.

Anchor Duration

The anchorDuration value is a number in seconds (for example, 1.2) and defines how long the anchor scroll animation takes, with higher values creating slower, more cinematic movement and lower values keeping it quick and direct.

Anchor Offset

The anchorOffset value is a number in pixels (for example, 80) and controls how far from the top the scroll stops when navigating to an anchor, which is useful when a sticky header might otherwise overlap the target section.