Дизайн и CSS, CSS3
Задайте элементу #go-top свойство position:fixed, чтобы его позиция была зафиксирована на странице. Тег span не обязателен. Я добавил его для отображения изображения со стрелкой. Я также добавил transition:1s (1s = 1 second) для эффекта при наведении курсора. Для тега body: <body id="top">
<p id="go-top">
<a href="#top"><span></span>Вверх</a>
</p>
#go-top {
position: fixed;
bottom: 30px;
margin-left: -150px;
}
#go-top a {
width: 108px;
display: block;
text-align: center;
font: 11px/100% Arial, Helvetica, sans-serif;
text-transform: uppercase;
text-decoration: none;
color: #bbb;
/* замедление */
-webkit-transition: 1s;
-moz-transition: 1s;
transition: 1s;
}
#go-top a:hover {
color: #000;
}
/* изображение со стрелкой (тег span) */
#go-top span {
width: 108px;
height: 108px;
display: block;
margin-bottom: 7px;
background: #ddd url(up-arrow.png) no-repeat center center;
/* закругленные углы */
-webkit-border-radius: 15px;
-moz-border-radius: 15px;
border-radius: 15px;
/* замедление */
-webkit-transition: 1s;
-moz-transition: 1s;
transition: 1s;
}
#go-top a:hover span {
background-color: #777;
}
Код jQuery
Ниже представлен код JavaScript (вы можете вставить его куда угодно на странице). Он скрывает элемент #go-top (в моем примере это
). Затем проверяет значение позиции верхней полосы прокрутки (scrollTop), и если оно больше, чем 100, отображает элемент #go-top, в противном случае, прячет его. Следующая часть кода - это функция обработки события клика по кнопке. Если произведен клик по кнопке, значение scrollTop тега body установится в 0.
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.3/jquery.min.js"></script>
<script>
{literal}
$(document).ready(function(){
// hide #go-top first
$("#go-top").hide();
// fade in #go-top
$(function () {
$(window).scroll(function () {
if ($(this).scrollTop() > 100) {
$('#go-top').fadeIn();
} else {
$('#go-top').fadeOut();
}
});
// scroll body to 0px on click
$('#go-top a').click(function () {
$('body,html').animate({
scrollTop: 0
}, 800);
return false;
});
});
});
{/literal}
</script>
А что, если JavaScipt отключен?
Заметьте, что кнопка перехода на верх ссылается на якорь #top, который является идентификатором тега body. В принципе, нет необходимости задавать какую-либо ссылку-якорь, так как jQuery позволяет прокручивать на любую часть страницы. Тем не менее лучше её все-таки задать на случай, если JavaScript не поддерживается в том или ином браузере.
Исходники и демо (если зарегистрирован):