CSS3 Animate Out: hover - PullRequest
       11

CSS3 Animate Out: hover

17 голосов
/ 23 ноября 2011

Я настраиваю простую анимацию, которая выводит немного дополнительной информации, когда вы наводите курсор на изображение. Часть резервного копирования jQuery написана и работает нормально, хотя проблема, с которой я сталкиваюсь, заключается в том, чтобы заставить анимацию CSS3 работать наоборот, когда пользователь зависает.

Так что, когда вы зависаете, это прекрасно работает, но как только вы парите, элементы просто исчезают. Я хотел бы знать, есть ли способ заставить их анимировать задом наперед, когда мышь зависает в другом месте. Большое спасибо!

#recent-work div { position: relative; width: 300px; height: 168px; overflow: hidden; }
                
                #recent-work div:hover .recent-project-type {  
                    animation-name: showType;
                    animation-duration: .5s;
                    animation-timing-function: ease;
                    animation-delay: 0;
                    animation-iteration-count: 1;
                    animation-direction: normal;
                    animation-play-state: running;
                    -moz-animation-name: showType;
                    -moz-animation-duration: .5s;
                    -moz-animation-timing-function: ease;
                    -moz-animation-delay: 0;
                    -moz-animation-iteration-count: 1;
                    -moz-animation-direction: normal;
                    -moz-animation-play-state: running;
                    -webkit-animation-name: showType;
                    -webkit-animation-duration: .5s;
                    -webkit-animation-timing-function: ease;
                    -webkit-animation-delay: 0;
                    -webkit-animation-iteration-count: 1;
                    -webkit-animation-direction: normal;
                    -webkit-animation-play-state: running;
                    top: 0;
                }
                
                #recent-work div:hover .recent-project-title {  
                    animation-name: showTitle;
                    animation-duration: .5s;
                    animation-timing-function: ease;
                    animation-delay: 0;
                    animation-iteration-count: 1;
                    animation-direction: normal;
                    animation-play-state: running;
                    -moz-animation-name: showTitle;
                    -moz-animation-duration: .5s;
                    -moz-animation-timing-function: ease;
                    -moz-animation-delay: 0;
                    -moz-animation-iteration-count: 1;
                    -moz-animation-direction: normal;
                    -moz-animation-play-state: running;
                    -webkit-animation-name: showTitle;
                    -webkit-animation-duration: .5s;
                    -webkit-animation-timing-function: ease;
                    -webkit-animation-delay: 0;
                    -webkit-animation-iteration-count: 1;
                    -webkit-animation-direction: normal;
                    -webkit-animation-play-state: running;
                    bottom: 0;
                }
            
            .recent-project-title { position: absolute; left: 0; right: 0; bottom: -34px; padding: 8px 10px; background: rgba(0,0,0,.75); text-decoration: none; border: 0; font-size: 20px; font-weight: 400; color: #fff; }
                .recent-project-title:hover { color: #ff9900; text-decoration: none; }
                
            .recent-project-type { position: absolute; left: 0; top: -26px; padding: 4px 8px; font-size: 12px; font-weight: 600; background: #ff9900; text-transform: uppercase; color: #111; }
                .recent-project-type:hover { color: #fff; text-decoration: none; }

@keyframes showType {
    from { top: -26px; }
    to { top: 0; }
}

@-moz-keyframes showType {
    from { top: -26px; }
    to { top: 0; }
}

@-webkit-keyframes showType {
    from { top: -26px; }
    to { top: 0; }
}

@keyframes showTitle {
    from { bottom: -34px; }
    to { bottom: 0; }
}

@-moz-keyframes showTitle {
    from { bottom: -34px; }
    to { bottom: 0; }
}

@-webkit-keyframes showTitle {
    from { bottom: -34px; }
    to { bottom: 0; }
}
<div class="row" id="recent-work">
            <div class="span-one-third">
                <a href="#" class="recent-project-image"><img src="http://dl.dropbox.com/u/1762184/recent-work01.png" width="300" height="168"></a>
                <a href="#" class="recent-project-title">Philly</a>
                <a href="#" class="recent-project-type">Video</a>
            </div>
</div>

Ответы [ 3 ]

11 голосов
/ 23 ноября 2011

Вам не нужны ключевые кадры для чего-то такого простого.

Я сделал вам демо (только с -webkit префиксами Vender, чтобы все было просто).

2 голосов
/ 23 ноября 2011

Это также может быть сделано с переходами CSS, это менее мощный, но более простой. Идея состоит в том, чтобы иметь div, содержащий верхнюю и нижнюю ссылки, но он больше, чем div-обертка, поэтому части скрыты. Когда вы наводите на него курсор, он уменьшает высоту, поэтому ссылки видны. Чтобы оживить его вперед и назад, вы добавляете «transition: height 1s» к CSS из div. Если у меня будет время позже, я постараюсь написать.

1 голос
/ 23 ноября 2011

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

...