Can I Position An Element Fixed Relative To Parent?


Answer :

The CSS specification requires that position:fixed be anchored to the viewport, not the containing positioned element.

If you must specify your coordinates relative to a parent, you will have to use JavaScript to find the parent's position relative to the viewport first, then set the child (fixed) element's position accordingly.

ALTERNATIVE: Some browsers have sticky CSS support which limits an element to be positioned within both its container and the viewport. Per the commit message:

sticky ... constrains an element to be positioned inside the intersection of its container box, and the viewport.

A stickily positioned element behaves like position:relative (space is reserved for it in-flow), but with an offset that is determined by the sticky position. Changed isInFlowPositioned() to cover relative and sticky.

Depending on your design goals, this behavior may be helpful in some cases. It is currently a working draft, and has decent support, aside from table elements. position: sticky still needs a -webkit prefix in Safari.

See caniuse for up-to-date stats on browser support.


Let me provide answers to both possible questions. Note that your existing title (and original post) ask a question different than what you seek in your edit and subsequent comment.


To position an element "fixed" relative to a parent element, you want position:absolute on the child element, and any position mode other than the default or static on your parent element.

For example:

#parentDiv { position:relative; } #childDiv { position:absolute; left:50px; top:20px; } 

This will position childDiv element 50 pixels left and 20 pixels down relative to parentDiv's position.


To position an element "fixed" relative to the window, you want position:fixed, and can use top:, left:, right:, and bottom: to position as you see fit.

For example:

#yourDiv { position:fixed; bottom:40px; right:40px; } 

This will position yourDiv fixed relative to the web browser window, 40 pixels from the bottom edge and 40 pixels from the right edge.


2016 Update

It's now possible in modern browsers to position an element fixed relative to its container. An element that has a transform property acts as the viewport for any of its fixed position child elements.

Or as the CSS Transforms Module puts it:

For elements whose layout is governed by the CSS box model, any value other than none for the transform property also causes the element to establish a containing block for all descendants. Its padding box will be used to layout for all of its absolute-position descendants, fixed-position descendants, and descendant fixed background attachments.

.context {   width: 300px;   height: 250px;   margin: 100px;   transform: translateZ(0); } .viewport {   width: 100%;   height: 100%;   border: 1px solid black;   overflow: scroll; } .centered {   position: fixed;   left: 50%;   bottom: 15px;   transform: translateX(-50%); }
<div class="context">   <div class="viewport">     <div class="canvas">        <table>         <tr>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>         </tr>         <tr>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>         </tr>          <tr>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>         </tr>          <tr>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>           <td>stuff</td>         </tr>       </table>        <button class="centered">OK</button>      </div>   </div> </div>


Comments

Popular posts from this blog

Converting A String To Int In Groovy

"Cannot Create Cache Directory /home//.composer/cache/repo/https---packagist.org/, Or Directory Is Not Writable. Proceeding Without Cache"

Android SDK Location Should Not Contain Whitespace, As This Cause Problems With NDK Tools