Rozważ poniższą stronę. Numer <img>
jest umieszczony absolutnie w stosunku do rodzica, a kiedy ładuję tę stronę w przeglądarce Safari lub Firefox, <img>
pojawia się w prawym górnym rogu, zgodnie z oczekiwaniami (patrz pierwszy obraz). Jednakże, gdy ramka zostanie usunięta z <div>
, na przykład, ustawiając border-width: 0
, <img>
pozycjonuje się absolutnie w stosunku do znacznika <p>
, jego rodzeństwo! Zobacz zdjęcie nr 2. Dlaczego to? Jaką różnicę powinna obramować?Tajemnica bezwzględnego pozycjonowania CSS
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<style type="text/css">
body {
margin: 0;
}
div {
position: relative;
left: 0;
top: 0;
border: 1px solid red;
}
img {
position: absolute;
right: 0;
top: 0;
}
p {
margin: 20px;
}
</style>
</head>
<body>
<div>
<img src="content/en/flag.png" />
<p>This is a test</p>
</div>
</body>
</html>
spróbuj użyć css-reset, a następnie sprawdź stronę. http://meyerweb.com/eric/tools/css/reset/ – Alon