<MyRusakov.ru />

Написание лайфхаков на Python

Написание лайфхаков на Python

Данный курс научит Вас автоматизировать самые разные задачи на языке Python, благодаря чему Вы сэкономите на рутине тысячи и тысячи часов своей жизни. Курс состоит из 20 примеров в различных областях: файлы и директории, медиа-файлы, Интернет, Web-мастеринг, Unreal Engine. Каждый пример упрощает ту или иную задачу в своей области, при этом каждый из них создаётся прямо на Ваших глазах и тщательно комментируется.

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

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

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

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

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

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

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

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

Зачем Вы изучаете программирование/создание сайтов?

Трансформация сложенных карточек на CSS

Трансформация сложенных карточек на CSS

Как развернуть сложенные в стопку карточки при наведении мыши?

HTML разметка

HTML структура состоит из трех карточек с текстовым контентом. Вся эта конструкция помещена в гибкий контейнер. Управлять карточками мы будем через CSS переменные. Чтобы объявить переменную, пишем два дефиса (--), имя переменной (j) и указываем значение переменной (цифру).

<div class="container">
  <div class="card" style="--i:-1">
    <div class="content" style="--j:1">
      <h2>Card 01</h2>
      <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod
      tempor incididunt ut labore et dolore magna aliqua.</p>
    </div>
      </div>
  <div class="card" style="--i:0">
    <div class="content" style="--j:2">
      <h2>Card 02</h2>
      <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod
      tempor incididunt ut labore et dolore magna aliqua.</p>
    </div>
  </div>
  <div class="card" style="--i:1">
    <div class="content" style="--j:3">
      <h2>Card 03</h2>
      <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod
      tempor incididunt ut labore et dolore magna aliqua.</p>
    </div>
  </div>
</div>


Трансформация сложенных карточек на CSS.

CSS код

.container{
    position: relative;/*относительное позиционирование*/
    width: 1100px;/*ширина контейнера*/
    height: 400px;/*высота контейнера*/
    display: flex;/*технология флексбокс*/
    justify-content: space-between;/*горизонтальное расположение карточек*/
    align-items: center;/*вертикальное выравнивание*/
}


Трансформация сложенных карточек на CSS.

Трансформация карточек в стопку.

.container .card{
    position: absolute;/*абсолютное позиционирование*/
    top: calc(50% - 200px);/*верхняя координата*/
    left: 50%;/*левая координата*/
    transform: translate(-50%,calc(100px * var(--i))) rotate(40deg) skew(-20deg,-10deg);/*расчет*/
    width: 300px;/*ширина карточки*/
    height: 400px;/*высота карточки*/
    background: #fff;/*цвет карточки*/
    z-index: calc(-1 * var(--i));/*формула для распределения карточек по слоям*/
    box-shadow: 25px 25px 100px rgba(0,0,0,0.2);/*тень для карточки*/
    transition: 0.5s;/*плавный переход*/
    display: flex;/*технология флексбокс*/
    justify-content: center;/*горизонтальное выравнивание*/
    align-items: center;/*вертикальное выравнивание*/
}


Трансформация сложенных карточек на CSS.

Пока карточки лежат в стопке, сделаем текст прозрачным.

.container .card .content{
    color: #444;/*цвет текста*/
    opacity: 0;/*элемент полностью прозрачный*/
    transform: translateY(50px);/*смещение по оси Y*/
    transition: 0.5s;/*плавность действий*/
    transition-delay: 0s;/*задержка*/
    padding: 25px;/*поля вокруг текста*/
    text-align: center;/*текст в центре*/
}


Трансформация сложенных карточек на CSS.

Общие CSS-свойства для всех карточек для hover-эффекта.

.container:hover .card{
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 1;/*значение слоя*/
    opacity: 1;/*элемент полностью непрозрачный*/
    box-shadow: 0 25px 50px rgba(0,0,0,0.2);/*создание тени*/
}

Персональное обращение к каждой карточке через CSS псевдокласс :nth-child() для указания формулы, рассчитывающей трансформацию, угол поворота и искажения.

.container:hover .card:nth-child(1){
    transform: translate(calc(-50% - 350px),-50%) rotate(0deg) skew(0deg,0deg);/*формула*/
    z-index: 3;/*порядковый номер слоя*/
}
.container:hover .card:nth-child(2){
    transform: translate(calc(-50% - 0px),-50%) rotate(0deg) skew(0deg,0deg);
    z-index: 2;/*порядковый номер слоя*/
}
.container:hover .card:nth-child(3){
    transform: translate(calc(-50% + 350px),-50%) rotate(0deg) skew(0deg,0deg);
    z-index: 1;/*порядковый номер слоя*/
}
.container:hover .card .content{
    opacity: 1;/*элемент полностью непрозрачный*/
    transition-delay: 0.5s;/*задержка трансформации*/
    transition-delay: calc(0.2s * var(--j));/*вычисление задержки по формуле*/
    transform: translateY(0px);
}


Трансформация сложенных карточек на CSS.

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

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

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

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

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

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

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

  1. Кнопка:

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

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

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

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

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

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