Rolagem animada: scroll page e back to page

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">&uarr;</a>