Neste post você verá como é simples criar um scroll animado. Utilize este conhecimento para criar o efeito scroll page (muito utilizado em One Pages) e Back to Page (voltar ao topo).
No código abaixo criamos um link com a classe .scrollPage apontando para a ancora #ancora:
<a class="scrollPage" href="#ancora">Link 1</a> <a id="contato"></a>
Observe que a primeira linha representa nosso link, já a segunda é a ancora, em outras palavras, essa ancora irá marcar o local para o qual você deseja ir ao clicar no link.
Aqui temos o CSS que dará um estilo legal ao nosso botão btn-scroll-top (voltar ao topo):
#btn-scroll-top { position: fixed; bottom: 35px; right: 35px; width: 42px; height: 42px; text-align: center; line-height: 40px; background: #333; color: #fff; cursor: pointer; border: 1px solid #fff; border-radius: 5px; text-decoration: none; transition: opacity 0.5s ease-out; opacity: 0; } #btn-scroll-top:hover { background: #000; opacity: 1 !important; } #btn-scroll-top.show { opacity: 0.4; }
Esse javascript faz a mágica:
$('.scrollPage, .back-to-top').click(function (e) { e.preventDefault(); $('html, body').animate({ scrollTop: ($.attr(this, 'href') != '#') ? $($.attr(this, 'href')).offset().top : 0 }, 500); }); $(window).on('scroll', function () { if ($(window).scrollTop() > 100) $('#btn-scroll-top').addClass('show'); else $('#btn-scroll-top').removeClass('show'); });
Resumo do código. Linha:
- 1) Executa a rolagem animada se algum elemento com as classes scrollPage ou back-to-top forem pressionados. Observe que scrollpage rola até o elemento ancora, já back-to-top te leva de volta ao topo da página.
- 9) observa o evento de scroll (rolagem) da página. Se tivermos rolado 100 pixels o botão de btn-scroll-top (voltar ao topo) será exibido
E Para concluir adicione este botão antes do final da página, pode ser antes de inserir os arquivos javascript:
<a href="#" class="back-to-top" id="btn-scroll-top" title="Back to top">↑</a>