In the example of http://jsfiddle.net/sqk3k2nq/ , the elements are set to be fixed
at the same position.
HTML:
<div>
<span>This is A</span>
<div>
<span>This is B</span>
<div>
<span>This is C</span>
</div>
</div>
</div>
CSS:
div {
border: 1px solid red;
position: fixed;
top: 20px;
left: 20px;
}
However, if we add perspective: 1000px;
to div
, the position will look like relative
instead of fixed
. See http://jsfiddle.net/sqk3k2nq/1/
Why setting perspective
changes it to be relative
?
For some reason, I have to set perspective
to it and I wish A
, B
, and C
can still be in the same position. Is it possible?
Position fixed doesn't work with transform CSS property. It happens because transform creates a new coordinate system and your position: fixed element becomes fixed to that transformed element. To fix the problem you can remove transform CSS property from the parent element.
An element with position: fixed; is positioned relative to the viewport, which means it always stays in the same place even if the page is scrolled. The top, right, bottom, and left properties are used to position the element. A fixed element does not leave a gap in the page where it would normally have been located.
The perspective() CSS function defines a transformation that sets the distance between the user and the z=0 plane, the perspective from which the viewer would be if the 2-dimensional interface were 3-dimensional. Its result is a <transform-function> data type.
To create a fixed top menu, use position:fixed and top:0 . Note that the fixed menu will overlay your other content. To fix this, add a margin-top (to the content) that is equal or larger than the height of your menu.
Why does perspective changes fixed position in CSS?
Because perspective
establishes a containing block similar to the way position: relative;
does, which is stated in the transform module:
Perspective
The use of this property with any value other than none establishes a stacking context. It also establishes a containing block (somewhat similar to position: relative), just like the transform property does.
Since you're applying a perspective to every div in your example (and top, left properties) each div creates its own containing block and ends up pushed 20px to the right and bottom of the previous div.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With