Размещение изображения в правом верхнем углу - CSS


125

Мне нужно отобразить изображение в правом верхнем углу div (изображение представляет собой «диагональную» ленту), но сохранить текущий текст, содержащийся во внутреннем div, как если бы он был прикреплен к его верхней части.

Я пробовал разные вещи, например, включение изображения в другой div или определение его класса, например:

.ribbon {
   position: relative;
   top: -16px;
   right: -706px;
}

<div id="content">
   <img src="images/ribbon.png" class="ribbon"/>
   <div>some text...</div>
</div>

но безуспешно. Лучший результат, который я получил, - это прокрутка текста вниз с той же высотой изображения.

Любая идея?


7
Рекомендуемая литература: ALA: CSS Positioning 101 и ALA: CSS Floats 101 .
jensgram 02

Ответы:


237

Вы можете сделать это так:

#content {
    position: relative;
}
#content img {
    position: absolute;
    top: 0px;
    right: 0px;
}

<div id="content">
    <img src="images/ribbon.png" class="ribbon"/>
    <div>some text...</div>
</div>

28

Расположите divленту относительно, а ленту абсолютно внутри нее. Что-то вроде:

#content {
  position:relative;
}

.ribbon {
  position:absolute;
  top:0;
  right:0;
}

4

Глядя на ту же проблему, я нашел пример

<style type="text/css">
#topright {
    position: absolute;
    right: 0;
    top: 0;
    display: block;
    height: 125px;
    width: 125px;
    background: url(TRbanner.gif) no-repeat;
    text-indent: -999em;
    text-decoration: none;
}
</style>

<a id="topright" href="#" title="TopRight">Top Right Link Text</a>

Хитрость здесь в том, чтобы создать небольшой (я использовал GIMP) PNG (или GIF) с прозрачным фоном (а затем просто удалить противоположный нижний угол).

Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.