javascript - How can I make a DIV take up the rest of the height of a container div? - Stack Overflow

I have a div with two nested divs. The first child has varying height depending on its content, I want

I have a div with two nested divs. The first child has varying height depending on its content, I want the the 2nd divs height to be whatever is left over from the parent.

<div style="height:500px;">
   <div>Some Content Here</div>
   <div>This div needs to take up the rest of the space of its parent</div>
</div>

How can I do this?

Thanks, ~ck in San Diego

I have a div with two nested divs. The first child has varying height depending on its content, I want the the 2nd divs height to be whatever is left over from the parent.

<div style="height:500px;">
   <div>Some Content Here</div>
   <div>This div needs to take up the rest of the space of its parent</div>
</div>

How can I do this?

Thanks, ~ck in San Diego

Share Improve this question asked Jan 7, 2010 at 20:44 HcabnettekHcabnettek 12.9k38 gold badges129 silver badges192 bronze badges 2
  • 3 Same as stackoverflow./questions/1818467/… ? – Upperstage Commented Jan 7, 2010 at 20:46
  • Forget about Java Script solutions or hacks with table layout[enter link description here][1] [1]: stackoverflow./a/26558049/869661 – Kryszal Commented Aug 25, 2015 at 20:35
Add a ment  | 

2 Answers 2

Reset to default 9

It requires some javascript. I see you're using jQuery, so this should work:

Give some id to your parent div:

<div style="height:500px;" id="parent">
    <div>Some Content Here</div>
    <div>This div needs to take up the rest of the space of its parent</div>
</div>

Then in jQuery:

$('div#parent div:last').each(function() {
    var p = $(this).parent();
    $(this).height(p.height() - ($(this).offset().top - p.offset().top));
});

I think I've got a correct way to do it without Javascript:

<div style="height:500px; background:pink; overflow: hidden">
   <div style="background: yellow">stuff</div>
   <div style="height: 100%; background: red;">This div needs to take up the rest of the space</div>
</div>

The key being "overflow:hidden" on the main div, as setting the height of the 2nd div to 100% makes it 500 pixels tall.

发布者:admin,转转请注明出处:http://www.yc00.com/questions/1743664132a4486687.html

相关推荐

发表回复

评论列表(0条)

  • 暂无评论

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信