How can I stack a div on top of my main content without it rendering extra space on the bottom?

I have a dumbed down example of what I need below, but I basically want a floating sticky navigation bar based off the bottom of the view port. I tried a few basic things but it's my fundamental lack of experience in css that's stopping me from figuring it out. Usually I'm keen on getting things myself but I've been looking for a couple days now on and off on this issue but can't seem to resolve it. I am using react for this project but still vanilla js/css so that shouldn't change much.
Looking at the image, the "Some content" is 100vh and so the bottom bar is causing me to have to scroll a little. I want the bottom bar to be floating approx 5rem from the bottom and positioned on top (in terms of z axis) of the "some content" so that there would be no awkward extra little scroll. I am using react for this project but still vanilla js/css so that shouldn't change much. Basic code thusfar: (I know I have some tailwind but again, vanilla is fine I can convert between the two np)
<div className="flex items-center justify-center text-center text-3xl font-giest-ultralight bg-slate-700" style={{ width: "100vw", height: "100vh" }}>Some content</div>
<div className="flex bg-slate-900 text-xl font-giest-semibold">Bottom bar</div>
<div className="flex items-center justify-center text-center text-3xl font-giest-ultralight bg-slate-700" style={{ width: "100vw", height: "100vh" }}>Some content</div>
<div className="flex bg-slate-900 text-xl font-giest-semibold">Bottom bar</div>
Note the extra space in scroll bar
No description
5 Replies
missymae
missymae10mo ago
take a look at the
postion: fixed
postion: fixed
and
position: sticky
position: sticky
css properties, which will let you position an element relative to the viewport, for example using
position: fixed; bottom: 0px
position: fixed; bottom: 0px
Dennis
DennisOP10mo ago
That was one of the things I tried but I still get that annoying space on the bottom (as big as my floating bar is)
<div className="flex items-center justify-center text-center text-3xl font-giest-ultralight bg-slate-700" style={{ width: "100vw", height: "100vh" }}>Some content</div>
<div className="sticky bg-slate-900 text-xl font-giest-semibold" style={{ bottom: "5rem" }}>Bottom bar</div>
<div className="flex items-center justify-center text-center text-3xl font-giest-ultralight bg-slate-700" style={{ width: "100vw", height: "100vh" }}>Some content</div>
<div className="sticky bg-slate-900 text-xl font-giest-semibold" style={{ bottom: "5rem" }}>Bottom bar</div>
Kevin Powell
Kevin Powell10mo ago
use position: fixed instead of sticky, which will pull it out of the flow and not "save" that space for it
Dennis
DennisOP10mo ago
Hi kevin! Pleasure seeing you. That does fix the issue. How can I align it to the center? of the screen Update: I got it, just made the width 100% and that fixed it
Dennis
DennisOP10mo ago
Final result:

Did you find this page helpful?