Trzeba uporządkować trochę kod, więc zanotuj:
- Zamień sobie header na tagi <h1> oprócz tego pierwszego. Niech on będzie na samym szczycie:
<body>
<header>JS Documentation</header>
<main id="main-doc">
<nav id="navbar">
<!-- Lecisz z kodem dalej -->
</nav>
<section class="main-section" id="introduction">
<h1>Introduction</h1>
- Ustal wysokość i overflow dla body, header ustawimy aby był "sticky". Będzie on na samym szczycie strony:
body {
margin: 0;
padding: 0;
display: flex;
height: 100vh;
overflow: hidden;
}
header {
display: flex;
align-items: center;
justify-content: center;
background-color: #f4f4f4;
font-size: 2em;
height: 50px;
width: 100%;
position: fixed;
top: 0;
left: 0;
z-index: 1000;
}
- Navbar ustawimy "ręcznie", aby był przyklejony do lewej strony i się nie ruszał. Czyli podobnie do headera:
#navbar {
position: fixed;
left: 0;
top: 0;
width: 300px;
height: 100%;
background-color: #f4f4f4;
padding: 80px 0 0 20px;
box-shadow: 2px 0 5px rgba(0, 0, 0, 0.1);
overflow-y: auto;
}
#navbar ul {
list-style-type: none;
padding: 0;
font-size: 1.3rem;
font-weight: 350;
max-width: 65ch;
text-wrap: balance;
}
#navbar li {
margin-bottom: 10px;
}
#navbar a {
text-decoration: none;
color: black;
}
- Został nam main, tutaj ustalimy jego szerokość matematycznie i na wszelki schowamy mu scrolla poziomego:
#main-doc {
padding: 50px;
overflow-y: auto;
overflow-x: hidden;
height: calc(100vh - 40px);
margin-left: 300px;
width: calc(100% - 300px);
box-sizing: border-box;
}
I w zasadzie masz wszystko gotowe :D
A jeśli korzystasz z Visual Studio Code, pobierz sobie rozszerzenie Prettier. Moim zdaniem must have jesli chodzi o kodowanie - stylizuje Ci Twój kod aby był bardziej czytelny