ページトップリンク
-ページの指定の高さを超えたら出現し、フッター手前で止まる-
See the Pen 8-1-6 ページの指定の高さを超えたら出現し、フッター手前で止まる by 動くWebデザインアイディア帳 (@ugokuweb) on CodePen.
「Result」内のリンクをクリックして動きを確かめてね!
動きを実現する仕組み
jQuery で指定の高さまでスクロールをしたらページトップリンクにクラス名を付与する。
クラスが付与されたらCSS のアニメーションを使ってリンクを表示する。
また、Footer の位置をJavaScript で取得してFooter の手前までスクロールしたらCSS のbottomの値を直接操作しFooter の手前で止まるようにする。
[使用するライブラリ]
* jQuery
HTMLの書き方
- head終了タグ直前に自作のCSSを読み込みます。
<link rel="stylesheet" type="text/css" href="css/8-1-6.css"> </head>
- body内にページトップリンクとコンテンツのHTMLを記載します。
<header id="header"> <h1>Logo</h1> </header> <main> <section id="area-1"> <h2>Area 1</h2> <p>内容が入ります。</p> <!--/area1--></section> <section id="area-2"> <h2>Area 2</h2> <p>内容が入ります。</p> <!--/area2--></section> <section id="area-3"> <h2>Area 3</h2> <p>内容が入ります。</p> <!--/area3--></section> <section id="area-4"> <h2>Area 4</h2> <p>内容が入ります。</p> <!--/area4--></section> <!--/main--></main> <footer id="footer"><!--footerの手前で止まるようにする--> <p id="page-top"><a href="#">Page Top</a></p> <small>© copyright.</small> </footer>
- body 終了タグ直前に jQuery、動きを制御する自作のJS の2 つを読み込みます。
<script src="https://code.jquery.com/jquery-3.4.1.min.js" integrity="sha256-CSXorXvZcTkaix6Yvo6HppcZGetbYMGWSFlBw8HfCJo=" crossorigin="anonymous"></script> <!--自作のJS--> <script src="js/8-1-6.js"></script> </body>
自作のCSS内の書き方
/*========= ページトップのためのCSS ===============*/
/*リンクの形状*/
#page-top a{
display: flex;
justify-content:center;
align-items:center;
background:#942D2F;
border-radius: 5px;
width: 60px;
height: 60px;
color: #fff;
text-align: center;
text-transform: uppercase;
text-decoration: none;
font-size:0.6rem;
transition:all 0.3s;
}
#page-top a:hover{
background: #777;
}
/*リンクを右下に固定*/
#page-top {
position: fixed;
right: 10px;
z-index: 2;
/*はじめは非表示*/
opacity: 0;
transform: translateY(100px);
}
/* 上に上がる動き */
#page-top.UpMove{
animation: UpAnime 0.5s forwards;
}
@keyframes UpAnime{
from {
opacity: 0;
transform: translateY(100px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
/* 下に下がる動き */
#page-top.DownMove{
animation: DownAnime 0.5s forwards;
}
@keyframes DownAnime{
from {
opacity: 1;
transform: translateY(0);
}
to {
opacity: 1;
transform: translateY(100px);
}
}
/*検証のためのCSS*/
section{
padding: 500px 0;
}
#footer{
background:#333;
}
自作のJS内の書き方
//スクロールした際の動きを関数でまとめる
function PageTopAnime() {
var scroll = $(window).scrollTop(); //スクロール値を取得
if (scroll >= 200){//200pxスクロールしたら
$('#page-top').removeClass('DownMove'); // DownMoveというクラス名を除去して
$('#page-top').addClass('UpMove'); // UpMoveというクラス名を追加して出現
}else{//それ以外は
if($('#page-top').hasClass('UpMove')){//UpMoveというクラス名が既に付与されていたら
$('#page-top').removeClass('UpMove'); // UpMoveというクラス名を除去し
$('#page-top').addClass('DownMove'); // DownMoveというクラス名を追加して非表示
}
}
var wH = window.innerHeight; //画面の高さを取得
var footerPos = $('#footer').offset().top; //footerの位置を取得
if(scroll+wH >= (footerPos+10)) {
var pos = (scroll+wH) - footerPos+10 //スクロールの値+画面の高さからfooterの位置+10pxを引いた場所を取得し
$('#page-top').css('bottom',pos); //#page-topに上記の値をCSSのbottomに直接指定してフッター手前で止まるようにする
}else{//それ以外は
if($('#page-top').hasClass('UpMove')){//UpMoveというクラス名がついていたら
$('#page-top').css('bottom','10px');// 下から10pxの位置にページリンクを指定
}
}
}
// 画面をスクロールをしたら動かしたい場合の記述
$(window).scroll(function () {
PageTopAnime();/* スクロールした際の動きの関数を呼ぶ*/
});
// ページが読み込まれたらすぐに動かしたい場合の記述
$(window).on('load', function () {
PageTopAnime();/* スクロールした際の動きの関数を呼ぶ*/
});
// #page-topをクリックした際の設定
$('#page-top').click(function () {
$('body,html').animate({
scrollTop: 0//ページトップまでスクロール
}, 500);//ページトップスクロールの速さ。数字が大きいほど遅くなる
return false;//リンク自体の無効化
});
この技術を使ったサンプルサイト
バリエーション
を見る
「機能」に関わる
動き一覧
基礎から学びたい方へ
Webサイトの動きを実現する仕組みと
準備について基礎から学びたい方は
下記をまず読み、基本を理解してから
コピペしましょう
Webサイトの動きを
実現する仕組みと準備
書籍情報
紙面だからこそできるまとめ方でコードを説明し、
全体を俯瞰して調べることが出来る構成になっています。
もちろん、パーツのサンプルコードもzipでまとめてダウンロードできます。
購入をしてくださった方には特典がありますので是非チェックしてみてください!