ページトップリンクや固定ボタンでよく使う、特定の要素に入ったら出現するボタン。
何度やっても忘れるので備忘録として。
html・CSSは下記のように。デザインは好みに合わせて。
<p id="page-top"><a href="#">▲<br>Top</a></p>
#page-top a{
display: flex;
justify-content:center;
align-items:center;
background:#e82875;
border-radius: 50px;
width: 60px;
height: 60px;
color: #fff;
text-decoration: none;
text-align: center;
text-transform: uppercase;
font-size:1rem;
transition:all 0.3s;
line-height: 1.2;
}
#page-top a:hover{
background: #777;
}
@media screen and (max-width:768px) {
#page-top a:hover{
background:#e82875;
}
}
#page-top {
position: fixed;
right: 10px;
bottom:10px;
z-index: 2;
opacity: 0;
transform: translateY(100px);
}
@media screen and (max-width:768px) {
#page-top {
bottom:90px;
}
}
#page-top.UpMove{
animation: UpAnime 0.5s forwards;
}
@keyframes UpAnime{
from {
opacity: 0;
transform: translateX(100px);
}
to {
opacity: 1;
transform: translateX(0);
}
}
#page-top.DownMove{
animation: DownAnime 0.5s forwards;
}
@keyframes DownAnime{
from {
opacity: 1;
transform: translateX(0);
}
to {
opacity: 1;
transform: translateX(100px);
}
}
$(function () {
$(window).on('load scroll', function () {
var elemTop = $('.totop_active').offset().top;
var scroll = $(window).scrollTop();
if (scroll >= elemTop) {
$('#page-top').addClass('UpMove');
} else {
$('#page-top').removeClass('UpMove');
}
});
});
totop_activeというクラスがついた要素が出現したら出現。

コメント