네이버,유튜브,특정사이트 중 하나를 골라 스타일만 클론하는 과제.
트위치를 택했다. 반응형도 잘되고, 애니메이션도 꽤 들어가있고.
나중에 만들어볼 MERN스택 실시간 스트리밍 사이트를 만들때 도움 될 것 같았음.
가보자구~
골자는 이렇게 되어있다.
2차원 레이아웃이 필요해보이니 grid
를 사용하겠다.
화면을 보면 2행 2열이다. (footer는 fiexd로 고정시켜놓는다)
.app {
height: 100vh;
display: grid;
grid-template-columns: 250px 1fr;
grid-template-rows: 50px 1fr;
grid-template-areas:
"header header"
"nav main";
}
이렇게 짜면 잘 나올줄 알알았는데...
nav, main 둘 다 1fr
적용이 되질 않았다.
=> 아직도 왜 그런지 모르겠다.
$headerHeight: 50px;
.app {
min-height: 100vh;
display: grid;
grid-template-columns: 1fr 8fr;
grid-template-rows: $headerHeight 1fr;
}
.header {
display: flex;
position: sticky;
top: 0;
border: 4px solid green;
padding: {
left: 10px;
right: 10px;
}
justify-content: space-between;
grid-column: 1 / span 2;
}
.nav {
height: calc(100vh - $headerHeight);
position: sticky;
top: $headerHeight;
border: 4px solid royalblue;
}
.main {
border: 4px solid tomato;
}
일단 이렇게 해결했음.
sticky
속성은 부모 요소의 높이까지만 적용됨
따라서 부모 속성에 height: 100vh
가아닌 min-height:100vh
를 줘서 해결!!!
이제 끝까지 잘 따라온다
위, 아래구분 없이 1차원적인 레이아웃이다.
따라서 1차원 레이아웃에 자주 쓰이는 flex
를 사용할 것이다.
space-between
을 적용한다..header {
display: flex;
border: 4px solid green;
padding: {
left: 10px;
right: 10px;
}
justify-content: space-between;
}
짜라잔! 헤더의 기초레이아웃은 이렇게 해두고 nav로 넘어가보자!
역시 1차원적인 레이아웃이다.
이 역시 세 개의 큰 구획으로 나누면 될 것 같다.
gap
요소를 사용해 구역 간 사이를 벌린다.nav
에는 padding
을 사용해 내부간격을 벌린다..nav {
color: $navColor;
background-color: #efeff1;
height: calc(100vh - $headerHeight);
display: flex;
flex-direction: column;
gap: $navGap;
padding: $navGap;
position: sticky;
top: $headerHeight;
border: 4px solid royalblue;
> section {
width: 100%;
text-align: center;
> article {
border: 2px solid brown;
}
}
.nav__middleSection {
display: flex;
flex-direction: column;
gap: $navGap;
}
}
일단 기초틀은 잡아놨으니 이 정도로 해놓고 다음으로 넘어가보자.
위 아래가 연결되어있는데...카테고리 부분까지만 해보자
div
가 존재한다.(나누기 선과 더보기 버튼)천천히 해보자잉
생각보다 더 오래걸린다..
너비가 줄어들면 하나씩 제거되게 했는데...뭔가 어색하다.
일단 여기까지!
z-index
를 줘도 겹쳐보이면 배경색에 white
주면 해결됨
진짜 CSS 하나도 모르겠다 큰일났다 비상 쵸비상
기한 안에 하려고 막짜는중이라 클났따 리뷰때 다 고쳐야한다 비상...!!!