【jQuery】特定の要素に入ったら出現するボタン

ページトップリンクや固定ボタンでよく使う、特定の要素に入ったら出現するボタン。
何度やっても忘れるので備忘録として。

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というクラスがついた要素が出現したら出現。

コメント

タイトルとURLをコピーしました