我有以下代码:
<!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/