jQueryで画面をスクロールした時にヘッダーをフワッと表示する方法
1477 回閲覧されました
みなさんこんにちは、jonioです。
今回は画面をスクロールした時にヘッダーをフワッと表示する方法を説明します。
デモ画面
デモは↓です。
See the Pen
Untitled by hayata19791218 (@hayata19791218)
on CodePen.
コードの解説
HTMLとcssを↓にします。
//HTML
<!DOCTYPE html>
<html lang="ja" dir="ltr">
<head>
<meta charset="utf-8">
<title>jQueryでフェードイン</title>
<link rel="stylesheet" href="css/style.css">
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
</head>
<body>
<header>
<nav>
<ul>
<li>ナビゲーション1</li>
<li>ナビゲーション2</li>
<li>ナビゲーション3</li>
<li>ナビゲーション4</li>
<li>ナビゲーション5</li>
</ul>
</nav>
</header>
<header id="header" class="header">
<nav>
<ul>
<li>ナビゲーション1</li>
<li>ナビゲーション2</li>
<li>ナビゲーション3</li>
<li>ナビゲーション4</li>
<li>ナビゲーション5</li>
</ul>
</nav>
</header>
<main>
<div class="content">コンテンツ</div>
</main>
<script type="text/javascript" src="js/common.js"></script>
</body>
</html>
//css
header ul{
display: flex;
justify-content:space-between;
width: 80%;
margin-left:auto;
margin-right:auto;
}
header nav{
background-color:skyblue;
padding-top: 20px;
padding-bottom: 20px;
}
header{
width: 100%;
}
.content{
height: 5000px;
background-color:pink;
}
.header{
position:fixed;
top:-70px;
transition-duration:1s;
}
.fadein{
top:0px;
}
/* ここからreset.css */
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
margin:0;
padding:0;
border:0;
outline:0;
font-size:100%;
vertical-align:baseline;
background:transparent;
}
body {
line-height:1;
}
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section {
display:block;
}
nav ul {
list-style:none;
}
blockquote, q {
quotes:none;
}
blockquote:before, blockquote:after,
q:before, q:after {
content:'';
content:none;
}
a {
margin:0;
padding:0;
font-size:100%;
vertical-align:baseline;
background:transparent;
text-decoration:none;
}
del {
text-decoration: line-through;
}
abbr[title], dfn[title] {
border-bottom:1px dotted;
cursor:help;
}
hr {
display:block;
height:1px;
border:0;
border-top:1px solid #cccccc;
margin:1em 0;
padding:0;
}
input, select {
vertical-align:middle;
}
p,.nav{
margin:0;
}
/* ここまでreset.css */
22行目〜32行目の部分がスクロールした時に上からフワッと表示されるヘッダーです。
61行目〜65行目でスクロールした時にフワッと表示するヘッダーが画面の外に隠れるようにしています。
jQuery
まずはスクロールした時に表示するヘッダーを取得します。
$(function(){
const header = $("#header");
});
次に画面をスクロールした時を考えます。
$(function(){
const header = $("#header");
//ここから追加
$(window).on("scroll",function(){
});
//ここまで追加
});
画面に対して何かをする時は6行目の「$(window)」です。
次はスクロール量を取得します。
$(function(){
const header = $("#header");
$(window).on("scroll",function(){
let scroll = $(window).scrollTop(); //この行を追加
});
});
4行目の「.scrollTop()」でスクロール量を取得でき「$(window).scrollTop()」で画面のスクロール量を取得できます。
次は画面をスクロールするとヘッダーが上からフワッと表示できるようにします。
$(function(){
const header = $("#header");
$(window).on("scroll",function(){
let scroll = $(window).scrollTop();
//ここから追加
if(scroll > 100){
header.addClass("fadein");
}else{
header.removeClass("fadein");
}
//ここまで追加
});
});
8行目〜10行目でスクロール量が100pxを越えたらfadeinクラス(top:0)が画面の上に隠れていたヘッダーに付いて画面上に表示されます。
10行目〜12行目でスクロール量が100pxより小さくなったらfadeinクラスが外れて画面上に戻ります。
これで完成です。