Earlier this year I came across a question on SOF asking how can a child element that is fixed
inherit the width of its parent. I was shocked to see a solution that suggested using inherit
was up-voted several times! This is not the correct solution. So I wrote a somewhat technical article on how to approach it. Here's the made-for-dev version of that answer.
The truth is, you can't use inherit
reliably to set the width of the of the child element while its fixed. This has to do with a misunderstanding, or no understanding, of how fixed
actually works.
Understand Fixed
Unlike absolute
, fixed
doesn't position itself from its closest relative parent. Instead, fixed
positions itself relative to the viewport. The viewport will always stay fixed, which is why you get the effect that you do.
That being said, whenever you "inherit" any width it will be respective to the viewport. So it does us no good when we're trying set the width of our target element to the width of it's parent.
Learn more about the different behaviors of position.
Quick Solutions
Now that we have a better understanding of fixed
, here are two approaches to make this happen
Pure CSS
We can use pure CSS to fix this problem, but we would need to know the width in advance. Suppose that its parent element is 300px;
.parent{
width: 300px;
}
.parent .fixed_child{
position: fixed;
width: 300px;
}
JS
Now with mobile devices, we don't really have the luxury of having set widths, especially anything over 300px
. Using percentages won't work either, since it will be relative to the viewport and not the parent element. We can use JS, in this case with jQuery to achieve this. Lets take a look at a function that will always set the width of the parent at the given moment:
function toggleFixed () {
var parentwidth = $(".parent").width();
$(".child").toggleClass("fixed").width(parentwidth);
}
css:
.fixed{
position:fixed;
}
View in CodePen
Dynamic Widths
That's fine and dandy, but what happens if the width of the window changes while the user is still on the page, changing the parent element with this? While the parent may adjust its width, the child will stay the set width that the function set it. We can fix this with jQuery's resize()
event listener. First we'll need to split the function we created into two:
function toggleFixed() {
adjustWidth();
$(".child").toggleClass("fixed");
}
function adjustWidth() {
var parentwidth = $(".parent").width();
$(".child").width(parentwidth);
}
Now that we've separated each part, we can call them individually, we'll include our original button method that toggles the fixed and width:
$("#fixer").click(
function() {
toggleFixed();
});
And now we also add the resize event listener to the window:
$(window).resize(
function() {
adjustWidth();
})
View in CodePen
There! Now we have a fixed element who's size will be adjusted when the window is resized.
Conclusion
We've tackled this challenge by understanding fixed
position and it's limitations. Unlike Absolute, fixed
only relates to the view port and therefore cannot inherit its parent's width.
To solve this, we need to use some JS magic, which didn't take very much with jQuery, to achieve this.
In some cases, we need a dynamic approach with scaling devices of varying widths. Again, we took the JS approach.
Top comments (4)
On chrome, if you set a fixed width on the parent, it seems to work. However if the parent as a % width, it will revert back to the window
Looks like position
fixed
can ihnerit the width of the container if the container inherits its container: stackoverflow.com/a/5874318/5017391Following your above instructions, my child div only seems to inherit the parent div's width when I begin resizing the view. Do you know what could be causing this?
It sounds like you did not add a trigger to resize it in the first place, in this instruction it's linked to a button '#fixer' which will call the function on click, you could try doing it on document ready