2015-11-28 4 views
2

У меня есть изображения и текст, который отображается в центре изображения, когда кто-то висит над изображением.Вертикальный текст центра на изображении - динамически

HTML выглядит следующим образом:

<article> 
<div class="entry-content"> 
<a href="http://www.linktopost.com"> 
<h3 class="entry-title">Ring #1</h3> 
<img width="620" height="387" src="http://i.telegraph.co.uk/multimedia/archive/02725/scotch-whisky_2725818b.jpg" class="aligncenter" alt="Platzhalter_3"> 
</a> 
</div> 
</article> 

CSS:

article { 
    float:left; 
    width:30%; 
    display:block; 
} 

.entry-content { 
    width: 620px; 
    margin: 0 auto; 
    position: relative; 
    height: 387px; 
} 

.entry-content:hover .entry-title { 
    color: #000; 
    display: table-cell; 
    background-color: #fff; 
    opacity: 0.75; 
} 

.entry-title { 
    position: absolute; 
    width: 100%; 
    height: 100%; 
    z-index: 9999; 
    line-height: 387px; 
    text-align: center; 
    display: none; 
} 

article img { 
    position:absolute; 
} 

Вы можете увидеть здесь: http://codepen.io/anon/pen/rOXOez

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

Спасибо!

+0

вы можете использовать flex ... это лучший современный способ сделать это;) google flex align middle – Akxe

ответ

2

Раствор 1:

Относительное/Абсолютное позиционирование и центр с transform: translate()

https://jsfiddle.net/94efk8kz/

article { 
    position: relative; 
} 

.hover-content { 
    position: absolute; 
    width: 100%; 
    height: 100%; 
    top: 0; 
    left: 0; 
    right: 0; 
    bottom: 0; 
    background: white; 
    color: black; 
    opacity: 0; 
    -webkit-transition: all 0.3s ease-in-out; 
    -moz-transition: all 0.3s ease-in-out; 
    -o-transition: all 0.3s ease-in-out; 
    transition: all 0.3s ease-in-out; 
} 

.hover-content h3 { 
    position: absolute; 
    top: 50%; 
    left: 50%; 
    margin: 0; 
    -webkit-transform: translate(-50%, -50%); 
    -moz-transform: translate(-50%, -50%); 
    -ms-transform: translate(-50%, -50%); 
    -o-transform: translate(-50%, -50%); 
    transform: translate(-50%, -50%); 
} 

Solution 2:

Flexbox

https://jsfiddle.net/94efk8kz/1/

article { 
    position: relative; 
} 

img { 
    width: 100%; 
} 

.hover-content { 
    width: 100%; 
    height: 100%; 
    top: 0; 
    display: flex; 
    position: absolute; 
    align-items: center; 
    justify-content: center; 
    background: white; 
    color: black; 
    opacity: 0; 
    -webkit-transition: all 0.3s ease-in-out; 
    -moz-transition: all 0.3s ease-in-out; 
    -o-transition: all 0.3s ease-in-out; 
    transition: all 0.3s ease-in-out; 
} 

Раствор 3

CSS Таблицы

https://jsfiddle.net/94efk8kz/2/

.entry-content a { 
    float: left; 
    width:30%; 
    position: relative; 
    height: 100%; 
} 


.hover-content { 
    width: 100%; 
    height: 100%; 
    top: 0; 
    left: 0; 
    position: absolute; 
    background: white; 
    color: black; 
    opacity: 0; 
    bottom: 0; 
    right: 0; 
    -webkit-transition: all 0.3s ease-in-out; 
    -moz-transition: all 0.3s ease-in-out; 
    -o-transition: all 0.3s ease-in-out; 
    transition: all 0.3s ease-in-out; 
} 


.v-align { 
    display: table; 
    height: 100%; 
    margin: 0 auto; 
} 

.hover-content h3 { 
    display: table-cell; 
    vertical-align: middle; 
} 
+1

Это действительно лучшее решение, потому что вы используете 'transform: translate()'. Проблемы: вы не объясняете свой ответ, поэтому OP не знает, о чем вы говорите. Вторая проблема - совместимость. С вашим кодом в iOS не работает или в старых браузерах, таких как IE9/10. Вам нужно добавить '-webkit-transform' и' -ms-transform'. –

0

Попробуйте с этими изменениями

.entry-content { 
    width: initial; 
} 
.entry-content:hover .entry-title { 
    margin: 0; 
} 
.article img { 
    display: block; 
    /* position: absolute; remove this,avoid using positon absolute where you can */ 

    width: 100%; 
} 
Смежные вопросы