<div class="relative">
<div class="toTop">
<a href="#top" title="Retour en haut">
Retour en haut
</a>
</div>
</div>
<footer id="footer">
…
</footer>
.relative {
position:relative;
}
.toTop {
display:none;
position:fixed;
right:20px;
bottom:20px;
z-index:1000;
}
function toTop(element,footer){
var scroll = $(window).scrollTop();
var maxScroll = $(window).height() * 0.4;
if(scroll > maxScroll)
$(element).show();
else
$(element).hide();
if($(element).offset().top + $(element).height() >= $(footer).offset().top - 10)
$(element).css('position', 'absolute');
if($(document).scrollTop() + window.innerHeight < $(footer).offset().top)
$(element).css('position', 'fixed');
}
$(window).scroll(function() {
toTop('.toTop',"#footer");
});
$(window).resize(function() {
toTop('.toTop',"#footer");
});