2017-02-18 14 views
0

На моем веб-сайте я создал тег div, и я установил его фон для изображения, и всякий раз, когда изображение зависает, цвет темнеет. Теперь я также хочу, чтобы текст отображался горизонтально и вертикально по центру, когда изображение зависало. Я попытался добавить текст, но текст даже не отображается на изображении.Как добавить текст в изображение, когда изображение зависло?

Вот мой HTML:

<div id="countries-hitched-div"> 
    <h1> Places Hitched </h1>  
    <div id="first" class="image"> 
     <h1 id="first-text"> India </h1> 
     <div class="overlay"></div> 
    </div> 
</div> 

Вот мой CSS:

#first { 
    background: url('Images/Home Page/first-quote-image-final.jpg'); 
    position: relative; 
} 

.image { 
    width: 500px; 
    height: 500px; 
    position:relative; 
} 

.image:hover > .overlay { 
    width:100%; 
    height:100%; 
    position:absolute; 
    background-color:#000; 
    opacity:0.5; 
} 

#first-text { 
    position: absolute; 
    color: black 
} 

ответ

0

Внесите изменения в #first-text:

.image:hover #first-text { 
    position: absolute; 
    top: 0; 
    bottom: 0; 
    left: 0; 
    right: 0; 
    margin: auto; 
    height: 50px; 
    text-align: center; 
} 

Вы получите абсолютный элемент по центру (по вертикали и горизонтали) внутри относительного элемента.

+0

Спасибо за ваш ответ! –

0

Добавить эту поправку в вашем коде, это aligns накладываемого text в центре,

#first-text { 
text-align:center; 
position: absolute; 
color: black; 
width:100%; 
top:45%; 
} 
+0

@Piyush Maheshwari Надеюсь, это сработает. – frnt

+0

Спасибо за ваш ответ –

+0

Добро пожаловать :-) @PiyushMaheshwari Примите или проголосуйте, если он сработает. – frnt

0

Во-первых: Не устанавливайте слишком много новых свойств на :hover. Если возможно, установите все свойства на загрузку страницы и измените только необходимые свойства, если :hover 'ed или :focus' ed.

Далее вы получили несколько вариантов для центрирования h1:

+0

Как установить свойства для загрузки страницы и что есть: focus, так как я не профессионал в веб-разработке? Спасибо за ответ –

+0

Посмотрите на этот пример: http://i.imgur.com/hrucKnj.png Свойства «some-property» устанавливаются при загрузке страницы. ': hover' - псевдокласс, который активируется (в данном случае), зависающим этим элементом. Все свойства, установленные в нем, изменяются в зависимости от класса, в котором используется ': hover'. ': focus' - это еще один псевдокласс, как': hover', но с другим использованием. При нажатии в текстовом поле, например, активируется ': focus'. – TheLexoPlexx

0

Для центра попробуйте выравнивать по центру центр и для эффектов зависания попробуйте изменить непрозрачность. Что-то вроде:

#first { 
 
    background: url('Images/Home Page/first-quote-image-final.jpg'); 
 
    position: relative; 
 
} 
 
.image {  
 
    width: 500px; 
 
    height: 500px; 
 
    position:relative; 
 
} 
 
.image:hover > .overlay { 
 
    width: 100%; 
 
    height: 100%; 
 
    position: absolute; 
 
    background-color: #000; 
 
    opacity: .5; 
 
} 
 
#first-text { 
 
    position: absolute; 
 
    color: black 
 
} 
 
#first-text { 
 
     text-align:center; 
 
     position: absolute; 
 
     color: black; 
 
     width:100%; 
 
     top:45%; 
 
     opacity:0.0 
 
} 
 
#first:hover #first-text{ 
 
    opacity:1 
 
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script> 
 
<div id="countries-hitched-div"> 
 
     <h1> Places Hitched </h1> 
 
      <div id="first" class="image"> 
 
       <h1 id="first-text"> India </h1> 
 
       <div class="overlay"></div> 
 

 

 

 
      </div> 
 
</div>

+0

Я хочу, чтобы изображение было видимым, даже если оно не зависало, то, что я хочу, - это то, что изображение должно затемняться, когда оно зависнет. Спасибо за ответ –

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

  • Нет связанных вопросов^_^