2015-02-23 87 views
4

我有一个小的挑战,我没有找到任何解决方案堆栈溢出。文本正在使用绝对定位

这就是我的了:

wrong

这就是我想它:

correct

为了制造我使用绝对这个标题效果位置。我甚至不知道我的头衔的宽度和高度。因此,使用此解决方案时,大文本会中断。

我的HTML:

<div class="content"> 
    <h1 class="title">February 2015</h1> 
    <p>Mussum ipsum cacilds, vidis litro abertis. Consetis adipiscings elitis. Pra lá , depois divoltis porris, paradis. Paisis, filhis, espiritis santis. Mé faiz elementum girarzis, nisi eros vermeio, in elementis mé pra quem é amistosis quis leo. Manduma pindureta quium dia nois paga. Sapien in monti palavris qui num significa nadis i pareci latim. Interessantiss quisso pudia ce receita de bolis, mais bolis eu num gostis.</p> 
</div> 

我的CSS:

.content { 
    border: 3px double black; 
    padding-top: 60px; 
    position: relative; 
    width: 350px; 
} 

.content p { margin: 20px; } 

.title { 
    background: black; 
    border-radius: 5px; 
    color: white; 
    left: 50%; 
    padding: 10px; 
    position: absolute; 
    text-align: center; 
    transform: translate(-50%, -50%); 
    top: 0; 
} 

查看Codepen一个例子,让生活更轻松: http://codepen.io/caio/pen/ZYoyPb

回答

11

最简单的解决办法是将添加white-space: nowrap。这样做,h1文本不会破坏到一个新的行。 (updated example)

.title { 
    white-space: nowrap; 
    background: black; 
    border-radius: 5px; 
    color: white; 
    left: 50%; 
    padding: 10px; 
    position: absolute; 
    text-align: center; 
    transform: translate(-50%, -50%); 
    top: 0; 
} 

此外,你还可以添加text-overflow: ellipsis/overflow: hidden/width: 100%使得文本形成省略号,从来没有突破到一个新的生产线。 (example here)

+0

真棒!谢谢... :) – 2015-02-23 18:53:35

2

在这里,我已经为你做了一些小的CSS更改。

/* Cosmetics */ 
* { box-sizing: border-box; } 
body { margin: 50px; } 
p { margin: 0; } 


/* True Code */ 
.content { 
    border: 3px double black; 
    padding-top: 30px; 
    position: relative; 
    width: 350px; 
} 

.content p { margin: 20px; } 

.title { 
    background: black; 
    border-radius: 5px; 
    color: white; 
    left: 50%; 
    padding: 10px; 
    position: absolute; 
    text-align: center; 
    transform: translate(-50%, -50%); 
    top: 0; 
    white-space: nowrap; 
    margin-top: 0px; 
} 
1

你的代码是正确的,但左边的属性会破坏你的输出。因为.content div被设置为相对的,.title将保留在其中。所以你只需要改变你的.title使用transform的位置:translate();码。 瞧,你有你想要的输出。

您可能会注意到我已经给.content提供了padding-top,只是将标题放置在适当的位置。

改变的代码如下:

/* Cosmetics */ 
* { box-sizing: border-box; } 
body { margin: 50px; } 
p { margin: 0; } 


/* True Code */ 
.content { 
    border: 3px double black; 
    padding-top:10px; 
    position: relative; 
    width: 350px; 
} 

.content p { margin: 20px; } 

.title { 
    background: black; 
    border-radius: 5px; 
    color: white; 
    padding: 10px; 
    position: absolute; 
    transform: translate(22%,-110%); 
}