Скрыть переполнение в позиции относительно контейнера - PullRequest
0 голосов
/ 05 апреля 2020

У меня проблема, я сделал красивую кнопку с эффектом змеи, но мне нужно последнее, мне нужно скрыть переполнение, чтобы создать эффект змеи.

есть моя кнопка:

button

Я хочу скрыть эти части, с overflow: hidden; это работает с position: absolute;, но не с относительными.

body {
    padding: 30px;
}

.btn-order {
    position: relative;;
    background-color: #961a22;
    color: #ff7675;
    padding: 30px 60px;
    font-family: Helvetica;
    font-size: 30px;
    font-weight: 400;
    letter-spacing: 2px;
    text-transform: uppercase;
    text-decoration: none;
    box-shadow: 0 20px 50px rgba(0, 0, 0, .5);
    overflow: hidden;
}

.btn-order:before {
    content: '';
    position: absolute;
    top: 0px;
    left: 0px;
    bottom: 0px;
    width: 50%;
    background: rgba(255, 255, 255, 0.07);
}

.btn-order span:nth-child(1) {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 4px;
    background: linear-gradient(to right, #ffffff, #ff3a3a);
    animation: animate1 1.25s linear infinite;
}

@keyframes animate1 {
    0% {
       transform: translateX(-100%); 
    }
    100% {
        transform: translateX(100%); 
     }
}

.btn-order span:nth-child(2) {
    position: absolute;
    top: 0;
    right: 0;
    width: 4px;
    height: 100%;
    background: linear-gradient(to bottom, #ffffff, #ff3a3a);
    animation: animate2 1.25s linear infinite;
    animation-delay: 0.625s;
}

@keyframes animate2 {
    0% {
       transform: translateY(-100%); 
    }
    100% {
        transform: translateY(100%); 
     }
}

.btn-order span:nth-child(3) {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 100%;
    height: 4px;
    background: linear-gradient(to left, #ffffff, #ff3a3a);
    animation: animate3 1.25s linear infinite;
}

@keyframes animate3 {
    0% {
       transform: translateX(100%); 
    }
    100% {
        transform: translateX(-100%); 
     }
}

.btn-order span:nth-child(4) {
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    background: linear-gradient(to top, #ffffff, #ff3a3a);
    animation: animate4 1.25s linear infinite;
    animation-delay: 0.625s;
}

@keyframes animate4 {
    0% {
       transform: translateY(100%); 
    }
    100% {
        transform: translateY(-100%); 
     }
}
<a href="#" class="btn-order">
    <span></span>
    <span></span>
    <span></span>
    <span></span>
    COMMANDER
</a>

Спасибо за помощь:)

1 Ответ

0 голосов
/ 05 апреля 2020

Увеличение ширины тела может это исправить.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...