lenis - スクロールのスムーズさ

(How smooth scroll should be)

Created at: 2022-02-21 22:57:09
Language: JavaScript

レニス

エヌピーエム版

紹介

🚧まだWIPで、APIは新しいリリース🚧で変更される可能性があります

これは、スムーズなスクロール、軽量、勤勉、バタースクロールのように滑らかな私たちの見解です。デモを見る


顔立ち

  • パフォーマンス
  • 軽量 (~2Kb ジップ圧縮)
  • メインスレッドでスクロールを実行する
  • アクセシビリティ(CMD + Fページ検索、キーボードナビゲーション、ページ更新時のスクロール位置の維持など)
  • 外部イギリス空軍
  • SSRプルーフ
  • 意見がない
  • ツリーシェイク可能
  • カスタムスクロールイージング/デュレーション

特徴 機関車スクロール GSAP スクロールスムーザー レニス
ネイティブスクロールバー
「ホイール」イベントを聴く
スクロールエクスペリエンスを正規化する
アクセシビリティ
CSS スティッキー
IntsersectionObserver
オープンソース
内蔵アニメーションシステム
サイズ (gzip) 12.33キロバイト 26.08キロバイト 2.13キロバイト

装着

パッケージマネージャーの使用:

$ npm i @studio-freight/lenis

スクリプトの使用:

<script src="https://cdn.jsdelivr.net/gh/studio-freight/lenis@0.2.28/bundled/lenis.js"></script>

Setup

Basic setup

import Lenis from '@studio-freight/lenis'

const lenis = new Lenis({
  duration: 1.2,
  easing: (t) => Math.min(1, 1.001 - Math.pow(2, -10 * t)), // https://www.desmos.com/calculator/brs54l4xou
  direction: 'vertical', // vertical, horizontal
  gestureDirection: 'vertical', // vertical, horizontal, both
  smooth: true,
  mouseMultiplier: 1,
  smoothTouch: false,
  touchMultiplier: 2,
  infinite: false,
})

//get scroll value
lenis.on('scroll', ({ scroll, limit, velocity, direction, progress }) => {
  console.log({ scroll, limit, velocity, direction, progress })
})

function raf(time) {
  lenis.raf(time)
  requestAnimationFrame(raf)
}

requestAnimationFrame(raf)

Using custom scroll container

const lenis = new Lenis({
  wrapper: NodeElement, // element which has overflow
  content: NodeElement, // usually wrapper's direct child
})

Instance settings

Option Type Default Description
wrapper
NodeElement
window
Default element which has overflow
content
NodeElement
document.body
wrapper
's direct child
duration
number
1.2
Specifies the duration of the animation
easing
function
(t) => Math.min(1, 1.001 - Math.pow(2, -10 * t))
Specifies the rate of change of a specific value, our default is custom but you can pick one from Easings.net
direction
string
vertical
vertical
or
horizontal
scrolling.
gestureDirection
string
vertical
vertical
,
horizontal
or
both
.
smooth
boolean
true
Enable or disable 'smoothness'
mouseMultiplier
number
1
This value is passed directly to Virtual Scroll
smoothTouch
boolean
false
Enable or disable 'smoothness' while scrolling using touch. Note: We have disabled it by default because touch devices native smoothness is impossible to mimic
touchMultiplier
number
string
This value is passed directly to Virtual Scroll
infinite
boolean
false
Enable infinite scrolling!

Instance Methods

Method Description Arguments
raf(time)
Must be called every frame for internal usage.
scrollTo(target,{offset, duration, easing, immediate})
Scroll to a target.
target
: can be
Number
,
NodeElement
or
String
(CSS selector).
offset
:
Number
equivalent to scroll-padding-top.
duration
:
Number
scroll duration in seconds.
easing
:
Function
.
immediate
: ignore duration and easing.
on(id,callback({scroll,limit,velocity,direction}))
id
can be any of the following instance events to listen.
stop()
To pause the scroll
start()
To resume the scroll
destroy()
To destroy the instance and remove all events.

Instance Events

Event Callback Arguments
scroll
scroll
: returns scroll position.
limit
: returns scroll limit.
velocity
: returns scroll velocity.
direction
: returns
1
or
-1
.

Considerations

Things to consider if you want to add Lenis to your codebase will be listed here.

Make sure
scroll-behavior
is set to initial or not set at all (thanks @thagxt)

html {
  scroll-behavior: initial;
}

Keep html and body elements default sized (see this issue)

html,
body {
  min-height: 100%;
  height: auto;
}

Use
data-lenis-prevent
attribute on nested scroll elements. In addition, we advise you to add
overscroll-behavior: contain
on this element.

<div data-lenis-prevent>scroll content</div>

Manually use
lenis.scrollTo('#anchor')
on anchor link click (see this issue)

<a href="#anchor" onclick="lenis.scrollTo('#anchor')">scroll to anchor</a>

Limitations

  • no support of CSS scroll-snap
  • can only run 60fps maximum on Safari (source)

Tutorials


Plugins


Lenis in use


Authors

This set of hooks is curated and maintained by the Studio Freight Darkroom team:


License

The MIT License.