2014-10-11 3 views
0

Я пытаюсь перенести изображение на 10 пикселей на мышь, но по какой-то причине это не работает. Вот что я пробовал:Перемещение изображения вверх по мыши над

http://jsfiddle.net/w3qqv4vh/

CSS:

.image { 
    display: block; 
    position: absolute; 
    top: 0; 
    bottom: 0; 
    left: 0; 
    right: 0; 
    z-index: 2; 
    width: 238px; 
    height: auto; 
    margin-top: auto; 
    margin-right: auto; 
    margin-bottom: auto; 
    margin-left: auto; 
    overflow: hidden; 

.image:hover { 
    margin-bottom: 10px;  
    transition: margin-left .5s; 
    -moz-transition: margin-left .5s; /* Firefox 4 */ 
    -webkit-transition: margin-left .5s; /* Safari and Chrome */ 
    -o-transition: margin-left .5s; /* Opera */ 
} 
+0

http://jsfiddle.net/w3qqv4vh/2/ –

+0

для вашего основного класса .image, измените его на дисплее: вместо этого, и в позиции: относительный. После этого, когда вы используете событие hover, введите margin-top: -10px; –

ответ

1

Есть некоторые изменения, которые вы должны сделать на CSS.

CSS

.image { 
    display: block; 
    position: absolute; 
    top: 0; 
    left: 0; 
    right: 0; 
    z-index: 2; 
    width: 238px; 
    height: auto; 
    margin-right: auto; 
    margin-bottom: auto; 
    margin-left: auto; 
    overflow: hidden; 
    } 

.image:hover { 
    margin-top: -10px;  
    transition: margin-left .5s; 
    -moz-transition: margin-left .5s; /* Firefox 4 */ 
    -webkit-transition: margin-left .5s; /* Safari and Chrome */ 
    -o-transition: margin-left .5s; /* Opera */ 
} 

http://jsfiddle.net/w3qqv4vh/1/

0

переход применяется на .image не .image:hover и просто использовать transform

body { 
 
    background-color: rgb(255, 255, 255); 
 
    font-family: 'Source Sans Pro'; 
 
    font-size: 13px; 
 
    font-weight: 200; 
 
    line-height: 1.38; 
 
    color: #000000; 
 
} 
 

 

 
.image { 
 
    display: block; 
 
    position: absolute; 
 
    top: 0; 
 
    bottom: 0; 
 
    left: 0; 
 
    right: 0; 
 
    z-index: 2; 
 
    width: 238px; 
 
    height: auto; 
 
    margin-top: auto; 
 
    margin-right: auto; 
 
    margin-bottom: auto; 
 
    margin-left: auto; 
 
    overflow: hidden; 
 
    -webkit-transform:translateY(0); 
 
    transition: transform .5s ease; 
 
} 
 
.image:hover { 
 
    -webkit-transform:translateY(-10px); 
 
}
<img class="image" alt="" src="http://lorempixel.com/output/food-q-c-284-239-1.jpg">

Вы можете использовать отступы слишком

body { 
 
    background-color: rgb(255, 255, 255); 
 
    font-family: 'Source Sans Pro'; 
 
    font-size: 13px; 
 
    font-weight: 200; 
 
    line-height: 1.38; 
 
    color: #000000; 
 
} 
 

 

 
.image { 
 
    display: block; 
 
    position: absolute; 
 
    top: 0; 
 
    bottom: 0; 
 
    left: 0; 
 
    right: 0; 
 
    z-index: 2; 
 
    width: 238px; 
 
    height: auto; 
 
    margin: auto; 
 
    overflow: hidden; 
 
    transition: padding-bottom .5s ease; 
 
} 
 
    
 
.image:hover { 
 
    padding-bottom: 10px;  
 
    
 
}
<img class="image" alt="" src="http://lorempixel.com/output/food-q-c-284-239-1.jpg">

Jsfiddle

Смежные вопросы