コピペOK。これだけで#のリンクをクリックしたら自動でスクロール移動に。もちろんスマホ対応。
リンクをタップしたりクリックしたら、パッと切り替わるのではなく、にゅるーっと動いていく#リンクがある。これを導入する方法を紹介。
なめらかスクロールのデモページはこちら
用意するもの
・scroll.js
・jQueryファイル(HTMLで直接読み込むなら用意しなくてもいい)
HTMLへの記述方法
<script type=”text/javascript” src=”https://cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.min.js”></script><!– scroll –>
<head>
<script type=”text/javascript” src=”js/scroll.js”></script><!– scroll –>
<head>
こんな感じで、jqueryとscroll.jsを読み込む。
あとはリンクで #xxx といつも通り記述するとなめらかにスクロールしていく。
まとめてダウンロードする場合はこちら
・scroll.zip
jsファイルの内容と簡単な解説
$(document).ready(function(){
$(‘a[href*=#]’).click(function() {
if (location.pathname.replace(/^\//,”) == this.pathname.replace(/^\//,”)
&& location.hostname == this.hostname) {
var $target = $(this.hash);
$target = $target.length && $target
|| $(‘[name=’ + this.hash.slice(1) +’]’);
if ($target.length) {
var targetOffset = $target.offset().top;
$(‘html,body’)
.animate({scrollTop: targetOffset}, 1000);
return false;
}
}
});
});
上から順に、
a hrefの中に#を使っていた場合
そのハッシュ(#)をターゲットにして
なめらかにスクロールするアニメーションだよ
という意味。
.animate({scrollTop: targetOffset}, 1000);
ここの数字を大きくすればゆっくり動き、小さくすれば早く動く。
この例の1000だと、1000ミリ秒=1秒なので、1秒で目的地に到着する。
なめらかスクロールのデモページはこちら