css绝对定位,右对齐

我有以下代码
<!DOCTYPE html>
<html>
<head>
  <style>
     img
     {
         position:absolute;
         right:50px;
     }
  </style>
</head>

<body>
     <h1>This is a heading</h1>
     <img src="logocss.gif" width="95" height="84" />
</body>
</html>

http://www.w3schools.com/cssref/tryit.asp?filename=trycss_position_right

如果我将h1的样式更改为:
H1
{
位置:绝对的;
右:50像素;
}
那么h1和img都重叠了.

现在我没有提到img或h1的最高位置.所以在第一种情况下,当h1没有任何风格时,img单独留下h1并占据h1之后的下一个可用空间并且与右侧对齐(相隔50 px).但是当我提到h1相距50px(绝对定位)时,img和h1都重叠了.现在因为我没有提到最高位置那么为什么不是img单独留下h1并跟随它(而不是重叠它)?我知道我们正在使用绝对定位,这会使模糊地指定顶部位置,为什么它会自动假设img必须占据顶部:0位置?如果h1占据顶部:0位置那么它很好,因为它是第一个元素.但是img应该尊重h1的空间.

在此先感谢您的帮助.

解决方法

这是因为position:absolute从文档流中删除了元素 – 它们不再堆叠,因为它们绝对是位置.

我认为更好的方法是:

h1,img{
    float:right;
    margin-right:50px;
    clear:both;
}

jsfiddle:http://jsfiddle.net/R7bXZ/

更好的方式:

只需给出h1 text-align:right;.

jsfiddle:http://jsfiddle.net/KvMLb/2/

相关文章

前言 最近项目做完,用户需要兼容IE,于是开展了兼容性的调整工作。边调整边想感叹IE真是个沙雕。。特将...
前言 有些属性不是很常用,但是工作中遇到了,记录一下,方便学习。 1、text-indent text-indent 属性规...
前言 政府网站会遇到公祭日的时候,网站整体颜色变灰的情况。今天正好调了一下。在此把解决方案分享给大...
需求 项目里有个消息中心,当有消息的时候,小铃铛图标可以晃两下,提示当前有信息。 实现过程 书写css...
html代码 css代码 效果图
在一些界面上 , 如果每个icon都去找图片还是相当麻烦的 , 直接使用css画出icon就方便的多了 , 下面两个...