<MyRusakov.ru />

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

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

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

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

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

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

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

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

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

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

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

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

SVG hover эффект для кнопки

SVG hover эффект для кнопки

Формат SVG дает новые возможности для рисования различных фигур и анимирования их. Сегодня мы рассмотрим SVG hover эффект на кнопку. Создадим внешний контейнер с классом button и внутри него поместим тег svg. Внутри парного тега svg будет располагаться тег rest, изображающий прямоугольник без заливки и с позиционированием от верхнего левого угла браузера.

<div class="button">
    Hover Me
    <svg width="150" height="75" viewBox="0 0 150 75" xmlns="http://www.w3.org/2000/svg">
        <rect x='0' y='0' fill='none' width='150' height='75'/>
    </svg>
</div>

//CSS
body {
    background-color: #F5F5F5; /* цвет фона страницы */
    font-family: sans-serif; /* название шрифта */
}

Стилизация кнопки

.button {
    text-transform: uppercase; /* текст заглавными буквами */
    width: 150px; /* ширина кнопки */
    height: 75px; /* высота кнопки */
    color: #bf360c; /* цвет текста */
    text-align: center; /* текст по центру по горизонтали */
    line-height: 75px; /* текст по центру по вертикали */
    margin: 20px auto; /* внешние отступы у кнопки */
    position: relative; /* относительное позиционирование */
    cursor: pointer; /* курсор рука */
}


SVG hover эффект для кнопки.

SVG располагает большим арсеналом CSS свойств, отвечающих за стиль контуров.

svg {
    position: absolute; position: relative; /* абсолютное позиционирование */
    top: 0; /* привязка к верхнему углу */
    left: 0; /* привязка к левому углу */
}

svg rect {
    stroke: #bf360c; /* цвет контура прямоугольника */
    stroke-width: 2; /* ширина контура прямоугольника */
    transition: 0.8s; /* плавный переход между состояниями */
}


SVG hover эффект для кнопки.

Эффект наведения

Переходим к самому главному. Мы хотим, чтобы при наведении на кнопку, увеличивалась ширина контуров прямоугольника. Кроме того, сплошной контур линии должен меняться на прерывистую линию. За это отвечает свойство stroke-dasharray. Первым параметром данного свойства мы указываем ширину линии, а вторым параметром промежуток между линиями.

svg rect {
    stroke-dasharray: 20, 40;
}


SVG hover эффект для кнопки.

Зададим изначально максимально длинную линию с нулевым промежутком у свойства stroke-dasharray.

svg rect {
    stroke: #bf360c;
    stroke-width: 2;
    transition: 0.8s;
    stroke-dasharray: 400, 0; /* эффект сплошной линии */
}

При наведении на кнопку вместо сплошной линии появляется пунктирная линия.

.button:hover svg rect {
    stroke-width: 5;
    stroke-dasharray: 35, 275; /* пунктир и промежуток */
    stroke-dashoffset: 40; /* смещение пунктира */
}


SVG hover эффект для кнопки.

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

Мир фронтенда очень велик и разнообразен и как не утонуть в потоке информации? И с чего вообще начать? Я рекомендую идти от простого к сложному и последовательно изучить все базовые возможности HTML и CSS, по моему видеокурсу "Верстка сайта с нуля 2.0".

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

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

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

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

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

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

  1. Кнопка:

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

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

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

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

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

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