<MyRusakov.ru />

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

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

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

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

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

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

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

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

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

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

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

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

Имитация печатной машинки при наведении на текст

Имитация печатной машинки при наведении на текст

Пропишем внутри ссылок data*-атрибуты с названиями ссылок. Это нужно для передачи этих названий в функцию attr для получения hover-эффекта.

<ul>
    <li><a href="#" data-text="Home">Home</a></li>
    <li><a href="#" data-text="About">About</a></li>
    <li><a href="#" data-text="Services">Services</a></li>
</ul>

Разместим меню в центре страницы и стилизуем ссылки в меню навигации.

*{
    margin: 0;/*обнуление отступов*/
    padding: 0;/*обнуление полей*/
    font-family: consolas;/*шрифт*/
}
body{
    display: flex;/*подключение flexbox*/
    justify-content: center;/*горизонтальное выравнивание*/
    align-items: center;/*вертикальное выравнивание*/
    height: 100vh;/*на всю высоту*/
    background: #1c234a;/*цвет фона*/
}
ul{
    position: relative;/*относительное позиционирование*/
}
ul li{
    list-style: none;/*удаление черных маркеров*/
    margin: 0 20px;/*отступы для списков*/
    font-size: 4em;/*размер шрифта*/
}
ul li a{
    position: relative;
    color: rgba(255,255,255,.1);/*полупрозрачный цвет ссылок*/
    text-decoration: none;/*без подчеркивания*/
    font-weight: 700;/*толщина шрифта*/
}


Имитация печатной машинки при наведении на текст.

Передадим в функцию attr значения data-атрибутов.

ul li a:before{
    content: attr(data-text);/*функция с аргументом*/
    position: absolute;/*абсолютное позиционирование*/
    top: -1px;/*позиция сверху*/
    overflow: hidden;/*спрятать лишнее*/
    color: #1bfaad;/*цвет ссылок*/
    transition: 0.5s ease-in-out;/*плавный переход*/
    white-space: nowrap;/*не переносить пробелы*/
}
ul li a:after{
    content: '';/*нет контента*/
    position: absolute;
    top: -1px;
    overflow: hidden;
    color: #1bfaad;
    transition: 0.5s ease-in-out;
    white-space: nowrap;
}


Имитация печатной машинки при наведении на текст.

Выберем из меню самое длинное слово - "Services", посчитаем сколько у него символов и передадим это число в аргументы функции steps. Таким образом мы добьемся скачкообразной анимации с паузами между символами, похожей на печатную машинку.

ul:hover li a:before{
    animation: animate2 0.5s steps(8) forwards;
}
ul li:hover a:before{
    animation: animate 2s steps(8) forwards;
}

Создание покадровой анимации - при наведении на пункт меню, происходит побуквенное пропечатывание слова. В то время, как остальные пункты меню остаются в тени.

@keyframes animate{
    0%
    {
        width: 0;
    }
    100%
    {
        width: 387.063px;
    }
}
@keyframes animate2{
    0%
    {
        width: 387.063px;
    }
    100%
    {
        width: 0;
    }
}


Имитация печатной машинки при наведении на текст.

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

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

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

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

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

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

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

  1. Кнопка:

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

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

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

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

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

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