Span Background Color Across Viewport Width
I am trying to build a responsive navigation bar with CSS Grid layout that spans across the viewport width, but the inner items should be centred and aligned with other container e
Solution 1:
Since the background area you're looking to expand is for decorative purposes only (i.e., you're not using that area to convey content), then you can use CSS pseudo-elements instead of an actual HTML element.
Pseudo-elements become grid items when applied to a grid container (read more).
.container {
display: grid;
grid-template-columns: 1fr repeat(4, minmax(min-content, 150px)) 1fr;
border: 2px solid black;
height: 100vh;
}
.nav {
grid-area: 1 / 2 / 2 / span 4;
height: 50px;
background-color: grey;
border: 1px solid red;
position: relative;
}
.container::before {
grid-area: 1 / 1 / 2 / 2;
content: "";
background-color: grey;
height: 50px;
}
.container::after {
grid-area: 1 / -1 / 2 / -2;
background-color: grey;
height: 50px;
content: "";
}
.content {
grid-area: 2 / 2 / 2 / span 4;
height: 200px;
background-color: grey;
border: 1px solid red;
}
<body class="container">
<div class="nav">this box should stay aligned with the content box</div>
<div class="content">Content box</div>
</body>
Post a Comment for "Span Background Color Across Viewport Width"