スムーススクロールとは?jQuery・CSS・JavaScriptそれぞれでの使用方法について詳しく解説!

- システム
エンジニア - jQuery・CSS・JavaScriptでスムーススクロールする方法について教えてください。
- プロジェクト
マネージャー - 今回はWebサイトでスムーススクロールする方法について説明しましょう。
jQuery・CSS・JavaScriptでスムーススクロールする方法とは?
今回は、Webサイトでスムーススクロールする方法について説明します。
jQuery・CSS・JavaScriptそれぞれでスムーススクロールが実現できます。ソースコードを交えて紹介します。スムーススクロールする方法に興味のある方はぜひご覧ください。
スムーススクロールしない場合
まずは、スムーススクロールを実装しないケースを紹介します。HTMLは以下のように記述します。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" crossorigin="anonymous">
<script type="text/javascript" src="http://code.jquery.com/jquery-3.1.0.min.js"></script>
</head>
<body>
<h1 id="index">TOP</h1>
<a class="btn btn-primary" href="#1" role="button">Link1</a>
<a class="btn btn-primary" href="#2" role="button">Link2</a>
<a class="btn btn-primary" href="#3" role="button">Link3</a>
<div id="1">
<h2>Link1</h2>
<a class="btn btn-success" href="#index" role="button">TOP</a>
</div>
<div id="2">
<h2>Link2</h2>
<a class="btn btn-success" href="#index" role="button">TOP</a>
</div>
<div id="3">
<h2>Link3</h2>
<a class="btn btn-success" href="#index" role="button">TOP</a>
</div>
</body>
</html>
|
CSSは以下のように記述します。
1
2
3
|
div{
height: 1000px;
}
|
実行結果は以下のようになります。
See the Pen
smooth_scroll1 by kskumd (@kskumd)
on CodePen.
ボタンをクリックすると、即座にリンク先に移動します。これをスムーススクロールする方法を以降で紹介します。
jQuery
jQueryでのスムーススクロール実装方法を紹介します。jQueryは以下のように記述します。HTML,CSSは先ほどのままで構いません。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
$(function(){
// #で始まるリンクをクリックした場合
$('a[href^="#"]').click(function() {
// スクロールの速度
let speed = 400;
// スクロールタイプ
let type = 'swing';
// href属性の取得
let href= $(this).attr("href");
// 移動先の取得(hrefが#indexならトップ$(html)に、)
let target = $(href == "#index" ? 'html' : href);
// 移動先のポジション取得
let position = target.offset().top;
// animateでスムーススクロール
$('body,html').animate({scrollTop:position}, speed, type);
return false;
});
});
|
実行結果は以下のようになります。
See the Pen
smooth_scroll2 by kskumd (@kskumd)
on CodePen.
ボタンをクリックすると、スムーススクロールされていることが分かります。スクロールタイプは「swing」(変速)と「linear」(等速)があります。変更して動きの違いを確認してみてください。
CSS
CSSでのスムーススクロール実装方法を紹介します。jQueryは削除してください。CSSは以下のように変更します。HTMLはそのままで構いません。
1
2
3
4
5
6
|
html {
scroll-behavior: smooth;
}
div{
height: 1000px;
}
|
実行結果は以下のようになります。
See the Pen
smooth_scroll3 by kskumd (@kskumd)
on CodePen.
CSSでもスムーススクロールが実現できていることが分かります。
JavaScript
JavaScriptでのスムーススクロール実装方法を紹介します。CSSは以下のように変更します。(元に戻します)
1
2
3
|
div{
height: 1000px;
}
|
JavaScriptは以下のように記述します。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
// #で始まるリンクを取得
const jsSmoothScroll = document.querySelectorAll('a[href^="#"]');
// forで回してaddEventListenerする
for (let i = 0; i < jsSmoothScroll.length; i++){
jsSmoothScroll[i].addEventListener('click', (e) => {
e.preventDefault();
// href属性の取得
let href = jsSmoothScroll[i].getAttribute('href');
let target = document.getElementById(href.replace('#', ''));
const rect = target.getBoundingClientRect().top;
const offset = window.pageYOffset;
// 移動先のポジション取得
const position = rect + offset;
// window.scrollToでスクロール
window.scrollTo({
top: position,
behavior: 'smooth',
});
});
}
|
実行結果は以下のようになります。
See the Pen
smooth_scroll4 by kskumd (@kskumd)
on CodePen.
JavaScriptでもスムーススクロールが実現できていることが分かります。
- システム
エンジニア - Webサイトでスムーススクロールする方法、よく分かりました。
- プロジェクト
マネージャー - jQuery・CSS・JavaScriptのそれぞれでお好みのスムーススクロールをご紹介しましたので参考にしてください。
まとめ
いかがでしたでしょうか。Webサイトでスムーススクロールする方法について説明しました。
jQuery・CSS・JavaScriptそれぞれでスムーススクロールが実現できます。手軽に実現できることがお分かりいただけたと思います。好みの方法でスムーススクロールを実装してみてください。
ぜひご自身でソースコードを書いて、理解を深めてください。
FEnet.NETナビ・.NETコラムは株式会社オープンアップシステムが運営しています。
株式会社オープンアップシステムはこんな会社です
秋葉原オフィスには株式会社オープンアップシステムをはじめグループのIT企業が集結!
数多くのエンジニアが集まります。

-
スマホアプリから業務系システムまで
スマホアプリから業務系システムまで開発案件多数。システムエンジニア・プログラマーとしての多彩なキャリアパスがあります。
-
充実した研修制度
毎年、IT技術のトレンドや社員の要望に合わせて、カリキュラムを刷新し展開しています。社内講師の丁寧なサポートを受けながら、自分のペースで学ぶことができます。
-
資格取得を応援
スキルアップしたい社員を応援するために資格取得一時金制度を設けています。受験料(実費)と合わせて資格レベルに合わせた最大10万円の一時金も支給しています。
-
東証プライム上場企業グループ
オープンアップシステムは東証プライム上場「株式会社オープンアップグループ」のグループ企業です。
安定した経営基盤とグループ間のスムーズな連携でコロナ禍でも安定した雇用を実現させています。
株式会社オープンアップシステムに興味を持った方へ
株式会社オープンアップシステムでは、開発系エンジニア・プログラマを募集しています。
年収をアップしたい!スキルアップしたい!大手の上流案件にチャレンジしたい!
まずは話だけでも聞いてみたい場合もOK。お気軽にご登録ください。


新着案件New Job
-
開発エンジニア/東京都品川区/【WEB面談可】/在宅ワーク
月給29万~30万円東京都品川区(大崎駅) -
遠隔テストサービス機能改修/JavaScript/東京都港区/【WEB面談可】/テレワーク
月給45万~60万円東京都港区(六本木駅) -
病院内システムの不具合対応、保守/東京都豊島区/【WEB面談可】/テレワーク
月給30万~30万円東京都豊島区(池袋駅) -
開発/JavaScript/東京都豊島区/【WEB面談可】/テレワーク
月給50万~50万円東京都豊島区(大塚駅) -
債権債務システム追加開発/東京都文京区/【WEB面談可】/在宅勤務
月給62万~67万円東京都文京区(後楽園駅) -
PMO/東京都豊島区/【WEB面談可】/在宅勤務
月給55万~55万円東京都豊島区(池袋駅)