使用css定位HTML元素

时间:2013-09-03 14:13:41

标签: html css css-float css-position

HTML代码

<header>
  <h1>Event Heading</h1>
  <div class="meta">09 JUL 2014</div>
  <div class="textblock">Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Donec odio. Quisque volutpat mattis eros. Nullam malesuada erat ut turpis. Suspendisse urna nibh, viverra non, semper suscipit, posuere a, pede.</div>
</header>

问题

我有这种HTML结构,我无法编辑/重新排列。我想将h1,div.meta和div.textblock定位如下图所示。

由于HTML的顺序,我无法按照我想要的方式使用浮点数。

插图

Trying to achieve this result

3 个答案:

答案 0 :(得分:2)

这可以通过绝对定位来实现:

header { 
  position: relative;
  min-height: 100px; }

div.meta {
    position: absolute;
    width: 100px; height:100px;
    top:0; left:0;
    border: 1px solid red; }

header h1 {
  margin-left: 120px;
  border-bottom: 2px solid red; }

header div.textblock { margin-left: 120px; }

请参阅小提琴:http://jsfiddle.net/utsKx/

如果您想要响应式布局,可以将div.meta宽度和h1 / textblock margin-left更改为百分比。

修改 添加了标题的最小高度,以确保div.meta永远不会落在父标题块之外。 (感谢MarcAudet指出这一点)

答案 1 :(得分:0)

见这个例子:

Codepen Example

我认为这就是你要找的东西!

答案 2 :(得分:0)

您可以使用此演示

Code Pen Demo

<强> HTML

 <header>
  <div class="meta L">09 JUL 2014</div>
  <h1 class="R">Event Heading</h1>
  <div class="textblock R">Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Donec odio. Quisque volutpat mattis eros. Nullam malesuada erat ut turpis. Suspendisse urna nibh, viverra non, semper suscipit, posuere a, pede.</div>
</header>

<强> CSS

header
{
  width:650px;
  display:inline-block;
}
.meta
{
  width:150px;
  height:150px;
  border:1px solid red;
  margin:5px;
  font-size:22px;
  text-align:center;
}
h1,.textblock
{
  width:400px;
  text-align:left;
  border:1px solid red;
}
h1
{
  color:#B1003B;
  margin-top:5px;
}
.textblock
{
  margin-top:-22px;
}
.L
{
  float:left;
}
.R
{
  float:right;
}
.C1
{
  color:#000000;
  font-weight:bold;
  font-size:36px;
}
.C2,.C3
{
  color:#777777;
}

<强> JQuery的

var str = $(".meta").html();
s = str.split(' ');
$(".meta").html("<span class='C1'>"+s[0]+"</span></br><span class='C2'>"+s[1]+"</span></br><span class='C3'>"+s[2]+"</span>");