<MyRusakov.ru />

Профессия Web-разработчик

Профессия Web-разработчик

Этот комплект за 8 месяцев превратит Вас в Web-разработчика с нуля. Учиться достаточно 1 час в день.

Начнёте Вы с HTML, CSS и вёрстки сайтов. Потом перейдёте к программированию и JavaScript. Затем изучите PHP, MySQL, SQL, Python. Изучите Web-фреймворки Laravel и Django. Создадите 5 своих сайтов для портфолио.

Комплект содержит:

- 540 видеоуроков

- 110 часов видео

- 1205 заданий для закрепления материала из уроков

- 5 финальных тестов

- 7 сертификатов

- 12 Бонусных курсов

Подробнее
Подписка

Подпишитесь на мой канал на YouTube, где я регулярно публикую новые видео.

YouTube Подписаться

Подписавшись по E-mail, Вы будете получать уведомления о новых статьях.

Подписка Подписаться

Добавляйтесь ко мне в друзья ВКонтакте! Отзывы о сайте и обо мне оставляйте в моей группе.

Мой аккаунт Мой аккаунт Моя группа
Опрос

Какая тема Вас интересует больше?

Уменьшение фоновой картинки при скролле страницы

Уменьшение фоновой картинки при скролле страницы

Уже привычно, когда на главной странице сайте, первый экран занимает огромная картинка, вставленная фоном. Пользователь дальше скроллит вниз и фоновая картинка постепенно скрывается из вида. Однако этот процесс можно сделать гораздо интереснее, если при скролле картинка будет уменьшаться и в размерах. Получится эффект отдаления, ощущение глубины.

HTML код

Создадим блок с идентификатором header, куда в дальнейшем поместим фоновую картинку и секцию с длинным текстом.

<div id="header"></div>
<section>
    <h2>Background Size Change into Small when Scrolling</h2>
    <p>здесь будет много текста, чтобы появился скролл</p>
</section>

CSS код

Сначала увеличим размер фоновой картинки на 160%, чтобы при скролле картинка принимала свой первоначальный размер.

@import url('https://fonts.googleapis.com/css?family=Poppins:300,400,500,600,700&display=swap');
*{
    margin: 0;/*обнуление отступов*/
    padding: 0;/*обнуление полей*/
    box-sizing: border-box;/*реальная ширина элемента*/
    font-family: 'Poppins', sans-serif;/*название шрифта*/
}
#header{
    position: relative;/*относительное позиционирование*/
    width: 100%;/*на всю ширину экрана*/
    height: 100vh;/*на всю высоту*/
    background: url(bg.jpg);/*ссылка на фоновую картинку*/
    background-size: 160%;/*увеличение размера картинки*/
    background-position: center;/*позиция картинки в центре*/
    background-attachment: fixed;/*фон зафиксирован сверху*/
}
section{
    padding: 50px;/*промежуток между текстом и шапкой*/
    color: #111;/*цвет текста*/
}
section h2{
    font-size: 2.5em;/*размер шрифта*/
    margin-bottom: 10px;/*отступ снизу*/
}
section p{
    font-size: 1.2em;
}


Уменьшение фоновой картинки при скролле страницы.

JavaScript

Найдем на странице header и занесем его в переменную bg. Дальше будем отслеживать в браузере событие scroll и запускать функцию, когда оно произойдет. Функция должна сделать две вещи:

  • добавить в header свойство opacity с уменьшающимся значением до достижения полной прозрачности картинки.
  • изменить в header размер фона, по формуле (последняя строчка кода).
<script type="text/javascript">
    let bg = document.getElementById("header")
    window.addEventListener("scroll", function(){
        bg.style.opacity = 1 - +window.pageYOffset/700+'';
        bg.style.backgroundSize = 160 - +window.pageYOffset/12+"%";
})
</script>


Уменьшение фоновой картинки при скролле страницы.

Посмотрите пример на CodePen

Копирование материалов разрешается только с указанием автора (Михаил Русаков) и индексируемой прямой ссылкой на сайт (http://myrusakov.ru)!

Добавляйтесь ко мне в друзья ВКонтакте: http://vk.com/myrusakov.
Если Вы хотите дать оценку мне и моей работе, то напишите её в моей группе: http://vk.com/rusakovmy.

Если Вы не хотите пропустить новые материалы на сайте,
то Вы можете подписаться на обновления: Подписаться на обновления

Если у Вас остались какие-либо вопросы, либо у Вас есть желание высказаться по поводу этой статьи, то Вы можете оставить свой комментарий внизу страницы.

Порекомендуйте эту статью друзьям:

Если Вам понравился сайт, то разместите ссылку на него (у себя на сайте, на форуме, в контакте):

  1. Кнопка:

    Она выглядит вот так: Как создать свой сайт

  2. Текстовая ссылка:

    Она выглядит вот так: Как создать свой сайт

  3. BB-код ссылки для форумов (например, можете поставить её в подписи):

Комментарии (0):

Для добавления комментариев надо войти в систему.
Если Вы ещё не зарегистрированы на сайте, то сначала зарегистрируйтесь.