https://d2.naver.com/helloworld/854017
flex-grow
- 아이템의 확대에 관련된 속성
- 0 또는 자연수
- 기본값 0
- 0 : 컨텐츠크기로 고정 (늘어나지 않음)
- 1 이상 : 컨테이너를 완전히 채우도록 늘어남
<div class="container">
<div class="item">아이템</div>
</div>
.container {
display: flex; height: 100px;
border: 3px solid #333;
}
.item{
flex-grow: 0;
margin: 5px;
background-color:skyblue;
}
.container {
display: flex; height: 100px;
border: 3px solid #333;
}
.item{
flex-grow: 1;
margin: 5px;
background-color:skyblue;
}
아래와 같이 아이템에 마우스를 올리면 바가 늘어나는 효과를 만들수 있다.
.container {
display: flex; height: 100px;
border: 3px solid #333;
}
.item{
flex-grow: 0;
margin: 5px;
background-color:skyblue;
transition: .5s;
}
.item:hover{
flex-grow: 1;
}
flex-shrink
- 아이템의 축소에 관련된 속성
- 0 또는 자연수
- 기본값 1
- 0 : 컨텐츠크기로 고정 (줄어들지 않음)
- 1 이상 : 컨테이너 크기에 맞게 줄어듦
<div class="container">
<div class="item">아이템</div>
</div>
.container {
display: flex; height: 100px;
border: 3px solid #333;
width: 50%;
}
.item{
flex-shrink: 0;
margin: 5px;
background-color:orange;
width: 1300px;
}
.container {
display: flex; height: 100px;
border: 3px solid #333;
width: 50%;
}
.item{
flex-shrink: 1;
margin: 5px;
background-color:orange;
width: 1300px;
}
flex-basis
- 아이템의 기본크기 지정
- width 에서 사용하는 모든 단위 가능(px, %, em, rem, vw, vh)
- 기본값 auto
- 0 : 컨테이너를 기준으로 아이템 크기가 결정됨
- auto: 아이템의 크기를 고려하여 크기가 결정됨
- 고정값 : 아이템 크기가 고정됨
<div class="container">
<div class="item">중간 아이템</div>
<div class="item">정말정말 긴 아이템</div>
<div class="item">짧음</div>
</div>
.container {
display: flex; height: 100px;
border: 3px solid #333;
width: 50%;
}
.item{
margin: 5px;
background-color:skyblue;
flex-basis: auto;
text-align: center; line-height: 100px;
}
.container {
display: flex; height: 100px;
border: 3px solid #333;
width: 50%;
}
.item{
margin: 5px;
background-color:skyblue;
flex-basis: 150px;
text-align: center; line-height: 100px;
}
.container {
display: flex; height: 100px;
border: 3px solid #333;
width: 50%;
}
.item{
margin: 5px;
background-color:skyblue;
flex-basis: 0px;
text-align: center; line-height: 100px;
}
flex:1 을 적용한 경우 flex-basis: 0 은 컨테이너 크기에 맞춰 균등분배한다.
.container {
display: flex; height: 100px;
border: 3px solid #333;
width: 50%;
}
.item{
margin: 5px;
background-color:skyblue;
flex: 1; flex-basis: 0;
text-align: center; line-height: 100px;
}
flex:1 을 적용한 경우 flex-basis: auto 은 아이템에 들어간 컨텐츠 길이에 따라 차등분배된다. 컨텐츠가 길면 공간을 더 많이 가져가고 컨텐츠가 짧으면 공간을 더 적게 가져간다.
.container {
display: flex; height: 100px;
border: 3px solid #333;
width: 50%;
}
.item{
margin: 5px;
background-color:skyblue;
flex: 1; flex-basis: auto;
text-align: center; line-height: 100px;
}
flex
- flex-grow flex-shrink flex-basis 를 한번에 설정
- 한개의 숫자만 설정하면 flex-grow 만 설정됨 (flex-shrink: 1 / flex-basis: 0)
- flex: 1 (1 1 0) flex:2 (2 1 0) flex:3 (3 1 0)
- flex:1 은 flex-grow:1 flex-shrink: 1이므로 컨테이너 크기에 따라 아이템이 늘어나거나 줄어듦
- 모든 아이템에 flex:1 을 설정하면 크기가 균등분배됨
<div class="container">
<div class="item">중간 아이템</div>
<div class="item">정말정말 긴 아이템</div>
<div class="item">짧음</div>
</div>
.container {
display: flex; height: 100px;
border: 3px solid #333;
width: 50%;
}
.item{
margin: 5px;
background-color:skyblue;
flex: 1;
text-align: center; line-height: 100px;
}
flex:1 은 flex-grow:1 이므로 컨테이너가 커지면 아이템의 너비는 늘어난다.
.container {
display: flex; height: 100px;
border: 3px solid #333;
width: 100%;
}
.item{
margin: 5px;
background-color:skyblue;
flex: 1;
text-align: center; line-height: 100px;
}
flex:1 은 flex-shrink:1 이므로 컨테이너가 줄어듦면 아이템의 너비는 함께 줄어든다.
.container {
display: flex; height: 100px;
border: 3px solid #333;
width: 20%;
}
.item{
margin: 5px;
background-color:skyblue;
flex: 1;
text-align: center; line-height: 100px;
}
flex: initial - 줄어들기만 함
컨테이너 크기가 줄어들면 아이템의 크기도 함께 줄어들지만, 컨테이너 크기가 커져도 늘어나지는 않는다. 디바이스 크기가 작아질때 반응형을 적용하려면 기본값을 사용하면 된다. flex: 0 1 auto 와 같은 의미다.
<div class="container">
<div class="item">아이템</div>
</div>
.container{
display: flex;
height: 100px;
border: 3px solid #333;
}
.container .item{
width: 500px;
margin: 5px;
background-color: #333;
}
브라우저 창을 줄여가면서 실험해보자!
max-width 와 유사하게 동작한다.
flex:none - 크기 고정
아이템의 크기가 컨테이너 크기에 따라 늘어나거나 줄어들지 않고 고정된 크기를 가진다. 크기가 고정되어야 하는 아이템은 flex:none 으로 설정하면 된다. flex: 0 0 auto와 같은 의미다.
<div class="container">
<div class="item">아이템</div>
</div>
.container{
display: flex;
height: 100px;
border: 3px solid #333;
}
.container .item{
width: 500px;
margin: 5px;
background-color: #333;
flex: none;
}
컨테이너의 크기가 줄어들어도 아이템의 크기는 고정된다. 브라우저 창을 줄이거나 늘리면서 실험해보자!
flex: auto / flex: 1 - 늘어나거나 줄어듦
컨테이너 크기에 맞춰 아이템이 늘어나거나 줄어든다. 디바이스가 커지거나 작아질때 반응형웹을 적용하려면 flex:auto 로 설정하면 된다. flex: 1 1 auto 와 같은 의미다.
<div class="container">
<div class="item">아이템</div>
</div>
.container{
display: flex;
height: 100px;
border: 3px solid #333;
}
.container .item{
width: 500px;
margin: 5px;
background-color: #333;
flex: auto;
}
컨테이너의 크기에 맞춰 아이템이 늘어나거나 줄어든다. 브라우저 창을 줄이거나 늘리면서 실험해보자!
flexbox 와 margin: auto 함께 사용하기 - 특정 아이템의 위치만 독립적으로 이동시킴
컨테이너에 display:flex 를 설정하고 아이템 margin 에 auto 를 적용하면 아이템의 위치를 독립적으로 제어할 수 있다.
<div class="container">
<div class="item">아이템</div>
</div>
아이템을 세로방향으로 가운데 위치시키려면 아래와 같이 margin: auto 0 를 설정하면 된다.
.container{
display: flex;
height: 500px;
border: 3px solid #333;
}
.container .item{
margin: 5px; height: 50px;
background-color: #333;
margin: auto 0;
}
컨테이너의 display: flex 설정을 비활성화하면 동작하지 않는다.
.container{
/* display: flex; */
height: 500px;
border: 3px solid #333;
}
.container .item{
margin: 5px; height: 50px;
background-color: #333;
margin: auto 0;
}
아이템을 가로방향으로 가운데 위치시키려면 아래와 같이 margin: 0 auto 를 설정하면 된다.
.container{
display: flex;
height: 500px;
border: 3px solid #333;
}
.container .item{
margin: 5px; height: 50px;
background-color: #333;
margin: 0 auto;
}
아이템을 컨테이너의 정중앙에 위치시키려면 margin: auto auto 를 설정하면 된다. 물론 컨테이너에 display: flex 가 적용된 경우에 한해서다.
.container{
display: flex;
height: 500px;
border: 3px solid #333;
}
.container .item{
margin: 5px; height: 50px;
background-color: #333;
margin: auto auto;
}
.container{
display: flex;
height: 500px;
border: 3px solid #333;
}
.container .item{
margin: 5px; height: 50px;
background-color: #333;
margin-top: auto;
}
컨테이너에 display:flex 를 적용하고 아이템에 margin-top: auto 를 지정하면 컨테이너 하단에 딱 붙어있다. 개발자 도구에서 컨테이너 높이를 변경하면서 실험해보자!
1. 스크롤이 없는 100% 레이아웃
<div class="container">
<header>헤더</header>
<div class="tab">탭</div>
<main>
<aside>사이드바</aside>
<section>메인컨텐츠</section>
</main>
</div>
*{
box-sizing: border-box;
}
html, body{
margin: 0; padding: 0;
}
.container {
display: flex; flex-direction: column;
width: 100%; height: 100vh;
border: 3px solid #333;
}
우선 컨테이너를 브라우저 창 사이즈에 맞게 설정하고, flex-direction 을 column 으로 지정하여 헤더, 탭, 메인 영역이 나란히 세로로 나열되도록 한다.
.container header, .container .tab{
border: 3px solid #333;
height: 70px; margin: .1rem;
}
.container main{
border: 3px solid #333;
}
헤더와 탭의 높이를 동일하게 고정값으로 설정한다.
flex:1 을 설정하면 메인 영역은 브라우저 높이(컨테이너)에 따라 높이가 늘어나거나 줄어든다. 브라우저 높이를 줄이거나 늘려보자!
.container main{
border: 3px solid #333;
flex: 1;
}
.container main{
border: 3px solid #333;
flex: 1;
display: flex;
}
.container main aside, .container main section{
border: 3px solid #333;
}
메인 영역 안에 위치한 사이드바와 메인 컨텐츠를 가로로 나열하기 위하여 main 에 display: flex 를 설정한다.
사이드바는 너비가 변하지 않도록 고정값(px)으로 설정한다. 메인컨텐츠에 flex:1 을 지정하면 브라우저 전체 너비에서 400px 을 제외한 나머지 공간을 채운다. 브라우저 너비가 변하면 메인컨텐츠 너비가 유동적으로 변한다. 브라우저에서 한번 실험해보자!
.container main aside{
width: 400px;
flex: none;
}
.container main section{
flex: 1;
overflow: auto;
}
flex: none 은 flex-grow: 0 flex-shrink: 0 flex-basis: auto 의 의미다. 즉, 사이드바가 컨테이너의 크기에 따라 늘어나거나 줄어들지 않고 고정된 크기를 가진다. 또한, 메인컨텐츠는 너비가 줄어들면 스크롤이 되도록 한다.
2. 네비게이션
<header>
<div class="logo">logo</div>
<div class="search">
<input type="text" placeholder="검색어를 입력하세요.">
<button>검색</button>
</div>
<div class="gnb">로그인</div>
</header>
우선 헤더 안에 있는 로고, 검색창, 로그인 버튼을 가로방향으로 나열하기 위하여 header 에 display: flex 를 적용한다.
html, body{
margin: 0; padding: 0;
box-sizing: border-box;
}
header{
display: flex;
height: 70px;
border: 3px solid #333;
}
로고, 검색창, 로그인 버튼에 flex:none 을 적용하여 크기를 고정한다.
.logo, .search, .gnb{
flex: none;
background-color: #eee;
}
로그인 버튼에 margin-left: auto 를 적용하여 해당 버튼만 우측에 위치시킨다. margin-left: auto 는 자신의 좌측에 위치한 모든 요소를 다 밀어내면서 자신은 우측에 위치한다. 다른 아이템들과 별개로 위치를 독립적으로 잡아야 할때 사용하면 된다. margin-left: auto 를 적용하면 컨테이너인 header에 justify-content: space-between 을 줘도 적용되지 않는다.
.gnb {
margin-left: auto;
}
로고와 로그인 버튼에 고정너비를 지정해주고 디자인한다.
.logo, .gnb{
width: 100px; height: 100%;
background-color: #333; color: #fff;
}
검색창 영역과 버튼에 고정너비를 지정해준다.
.search{
width: 500px;
}
.search button{
width: 100px;
}
검색 버튼을 디자인한다.
.search button{
width: 100px;
background-color: #333; color: #fff;
border: none;
}
검색영역에 display: flex 를 적용하고 사용자 입력창에 flex:1 을 지정해서 검색영역에서 검색버튼의 크기를 제외한 나머지 공간을 모두 차지할 수 있도록 한다. 즉, 입력창의 너비는 400px 이 된다.
.search{
width: 500px;
display: flex;
}
.search button{
width: 100px;
background-color: #333; color: #fff;
border: none;
}
.search input{
flex: 1;
}
3. 브라우저 하단에 붙어있는 푸터
<div class="container">
<footer>푸터</footer>
</div>
컨테이너 높이를 브라우저 창 높이에 맞춘다. 컨테이너에 display: flex 를 주고, 푸터에 flex:1 을 적용하면 컨테이너 크기에 맞게 늘어나고 줄어든다. 푸터에 margin-top: auto 를 지정하면 푸터가 브라우저 하단에 고정된다. 브라우저 높이를 변경하면서 실험해보자! 물론 컨테이너에 align-items: flex-end를 줘도 동일하게 동작하지만 이렇게 되면 컨테이너 안에 푸터 이외의 다른 요소들도 함께 브라우저 하단에 고정된다. 즉, 푸터만 따로 배치하려고 할때 margin-top: auto 를 사용하면 된다.
*{
box-sizing: border-box;
}
html, body{
margin: 0; padding: 0;
}
.container{
display: flex;
height: 100vh;
border: 3px solid #333;
}
.container footer{
flex: 1;
height: 70px; margin: 5px;
background-color: #333;
margin-top: auto;
color: #fff;
font-size: 2rem; text-align: center;
}
4. 정렬이 다른 메뉴
<header>
<div class="logo">로고</div>
<div class="search">검색창</div>
<div class="signup">로그인</div>
</header>
컨테이너 안에 위치한 아이템에 space-evenly 를 적용하면 중앙에서 균등한 여백을 두고 정렬된다.
*{
box-sizing: border-box;
}
header{
display: flex;
justify-content: space-evenly;
height: 70px;
border: 3px solid #333;
}
header *{
width: 100px; height: 100%;
background-color: #333; color: #fff;
}
5. 유동 너비 박스
https://codepen.io/witblog/pen/oPyvEa
컨테이너가 줄어들면서 아이템의 컨텐츠가 잘리면서 점(.)으로 표시되는 레이아웃을 만들어보자!
<div class="container">
<div class="text">나는 지난주에 뭐했는지 기억이 잘 나지 않는다.</div>
<div class="text">나는 지난</div>
<div class="text">나는 지난주에 뭐했는지</div>
<div class="text">나는 지난주에</div>
<button>버튼</button>
</div>
컨테이너에 display: flex 를 적용하여 글자를 수평으로 나열한다.
*{
box-sizing: border-box;
}
.container{
display: flex;
height: 70px;
border: 3px solid #333;
}
flex: 0 1 auto 이므로 컨테이너가 줄어들면 아이템의 너비도 함께 줄어든다. 아이템의 너비가 줄어들면 내부에 있는 글자가 밖으로 삐져나오는데 overflow: hidden 을 주고, white-space: nowrap 으로 적용하면 아이템이 줄어들때 글자는 여러줄이 아니라 한줄에 가로로 길게 늘여뜨려진다. 여기에서 text-overflow: ellipsis 를 적용하면 아이템의 너비가 텍스트 길이보다 작아질때 점(.)으로 표시된다. 그리고 아이템의 너비는 300px 로 제한한다.
.container .text{
flex: 0 1 auto;
max-width: 300px;
margin: 5px;
border: 3px solid #333;
overflow:hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
6. 위아래로 흐르는 목록
핀터리스트나 쇼핑몰 사이트처럼 위아래로 나열되는 목록을 만들어보자!
<div class="container">
<div class="item">1</div>
<div class="item">2</div>
<div class="item">3</div>
<div class="item">4</div>
<div class="item">5</div>
<div class="item">6</div>
<div class="item">7</div>
<div class="item">8</div>
<div class="item">9</div>
<div class="item">10</div>
</div>
10개의 아이템 목록을 만든다. 컨테이너에 flexbox 를 적용하고 아래로 나열되도록 flex-direction: column 을 지정한다. 컨테이너 높이를 브라우저 창 높이로 제한하고 flex-wrap: wrap 을 적용하면 위아래로 흐르는 목록을 구현할 수 있다. 마지막으로 수평방향과 수직방향에 대하여 균등한 여백을 주기 위하여 space-evenly 를 적용한다.
*{
box-sizing: border-box;
}
html,body{
margin: 0; padding: 0;
}
.container{
display: flex;
flex-direction: column;
flex-wrap: wrap;
justify-content: space-evenly;
align-content: space-evenly;
height: 100vh;
border: 3px solid #333;
}
.container .item{
width: 200px; height: 200px;
margin: 10px;
background-color: #333; color: #fff;
font-size: 5rem;
}
<div class="actions">
<img src="" alt="profile-1">
<img src="" alt="profile-2">
<img src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcSpwSuc5_00-b2FxK198sY73ArVySbThSLAXQ&usqp=CAU" alt="profile-3">
<img src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTQEZrATmgHOi5ls0YCCQBTkocia_atSw0X-Q&usqp=CAU" alt="profile-4">
<img src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcRKDP-4Dg4s4b6YxTTriW24nV5Q0RL65zh7JA&usqp=CAU" alt="profile-5">
<img src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcRhGE2phgRinbSsr8VJrLNwB954CTc8UZ1JhQ&usqp=CAU" alt="profile-6">
<img src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTkQUg_P0cc8EgSCk-SdT8Yvcm6E5SbdfuhzA&usqp=CAU" alt="profile-7">
<img src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcRbMigoSI-w6bjLxl3qXVC3482EAbhYImiZXw&usqp=CAU" alt="profile-8">
<img src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcQFacn0pb12vsSRTPKRUDnxFrP8sj7st13r8A&usqp=CAU" alt="profile-9">
<img src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcRoZf-IXN17ph2s07rUcgVDwIpTxbOQh55noQ&usqp=CAU" alt="profile-10">
</div>
*{
box-sizing: border-box;
}
html,body{
margin: 0; padding: 0;
}
.actions{
display: flex;
flex-direction: column;
flex-wrap: wrap;
justify-content: space-evenly;
align-content: space-evenly;
height: 100vh;
border: 3px solid #333;
}
.actions img{
width: 200px; height: 200px;
margin: 10px;
background-color: #333; color: #fff;
font-size: 5rem;
}
이를 활용하면 아래와 같이 프로필 사진들을 위아래로 나열할 수 있다. 물론 제품사진 목록을 나열할 수도 있고, 의류목록도 나열할 수 있다.
*{
box-sizing: border-box;
}
html,body{
margin: 0; padding: 0;
}
.actions{
display: flex;
flex-direction: column;
flex-wrap: wrap;
justify-content: flex-start;
align-content: center;
height: 100vh;
border: 3px solid #333;
}
.actions img{
width: 200px; height: 200px;
margin: 10px;
background-color: #333; color: #fff;
font-size: 5rem;
border-radius: .5rem;
}
justify-content 와 align-items 설정을 수정하면 아래와 같이 된다.
참고로 columns 속성을 사용하면 플럭스박스보다 간단히 해결된다. columns 속성을 사용하는 예제는 아래에 링크를 걸어두었다.
https://syleemomo.tistory.com/52
7. 가로세로 비율을 유지하는 반응형 이미지 박스
<div class="container">
<div class="item">1</div>
<div class="item">2</div>
<div class="item">3</div>
<div class="item">4</div>
<div class="item">5</div>
<div class="item">6</div>
<div class="item">7</div>
<div class="item">8</div>
<div class="item">9</div>
</div>
컨테이너에서 아이템들의 너비가 일정비율로 유지되도록 하려면 flex-basis 를 적용하면 된다. 한줄에 3개의 아이템만 나열하려면 flex-wrap: wrap 과 flex-basis: 33.3% 을 설정하면 된다.
*{
box-sizing: border-box;
}
.container{
display: flex;
flex-wrap: wrap;
width: 50%; height: 800px; padding: 10px;
border: 3px solid #333;
}
.container .item{
flex-basis: 33.3%;
background-color: #333; color: #fff;
font-size: 3rem;
border: 2px solid yellow;
}
HTML 코드를 아래와 같이 수정한다.
<div class="container">
<div class="item">
<div class="img">이미지</div>
<button>버튼</button>
</div>
<div class="item">
<div class="img">이미지</div>
<button>버튼</button>
</div>
<div class="item">
<div class="img">이미지</div>
<button>버튼</button>
</div>
<div class="item">
<div class="img">이미지</div>
<button>버튼</button>
</div>
<div class="item">
<div class="img">이미지</div>
<button>버튼</button>
</div>
<div class="item">
<div class="img">이미지</div>
<button>버튼</button>
</div>
<div class="item">
<div class="img">이미지</div>
<button>버튼</button>
</div>
<div class="item">
<div class="img">이미지</div>
<button>버튼</button>
</div>
<div class="item">
<div class="img">이미지</div>
<button>버튼</button>
</div>
</div>
아이템에 다시 display: flex 와 flex-direction: column 을 설정해서 이미지와 버튼을 수직으로 나열한다. 버튼에 대한 스타일링을 해준다. 그리고 이미지에는 flex:auto 로 설정해서 컨테이너 사이즈에 따라 반응형이 되도록 한다.
*{
box-sizing: border-box;
}
.container{
display: flex;
flex-wrap: wrap;
width: 50%; height: 800px; padding: 10px;
border: 3px solid #333;
}
.container .item{
flex-basis: 33.3%;
background-color: #333; color: #fff;
font-size: 3rem;
border: 2px solid yellow;
display: flex;
flex-direction: column;
}
.container .item button{
margin-top: auto;
margin-bottom: .5rem; margin-left: .5rem; margin-right: .5rem;
height: 50px;
border: none;
background-color: orange;
cursor: pointer;
}
.container .item .img{
flex: auto; margin-bottom: 10px;
background-color:mediumspringgreen;
}
디바이스 크기가 줄어들때 한줄에 이미지가 2개, 1개만 보이도록 아래와 같이 반응형웹으로 flex-basis를 조절한다.
@media (max-width: 900px){
.container .item{
flex-basis: 50%;
}
}
@media (max-width: 700px){
.container .item{
flex-basis: 100%;
}
}
8. 반응형 페이지네이션 버튼
<div class="actions">
<button>1</button>
<button>2</button>
<button>3</button>
<button>4</button>
<button>5</button>
</div>
버튼을 감싸고 있는 컨테이너에 display: flex 를 적용한다.
.actions{
display: flex;
width: 500px; height: 30px;
border: 3px solid #333;
}
버튼에 flex: auto 를 설정하면 컨테이너 크기에 따라 버튼의 너비가 변한다. 지금은 고정값이지만 개발자도구에서 컨테이너의 너비값을 변경하면 버튼의 너비도 함께 변한다. flex: auto 는 flex: 1과 동일한 의미로 컨테이너 크기에 따라 내부 아이템이 늘어나거나 줄어든다.
.actions button{
flex: auto;
}
버튼에 마우스를 올렸을때 버튼의 너비를 키우려면 flex 값을 1보다 크게 설정하면 된다.
.actions{
display: flex;
width: 500px; height: 30px;
border: 3px solid #333;
}
.actions button{
flex: auto;
transition: .5s;
}
.actions button:hover{
flex: 3;
}
이렇게 하면 반응형 페이지 버튼을 만들수 있다.
<div class="actions">
<img src="" alt="profile-1">
<img src="" alt="profile-2">
<img src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcSpwSuc5_00-b2FxK198sY73ArVySbThSLAXQ&usqp=CAU" alt="profile-3">
<img src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTQEZrATmgHOi5ls0YCCQBTkocia_atSw0X-Q&usqp=CAU" alt="profile-4">
<img src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcRKDP-4Dg4s4b6YxTTriW24nV5Q0RL65zh7JA&usqp=CAU" alt="profile-5">
</div>
.actions{
display: flex;
height: 300px;
border: 3px solid #333;
}
.actions img{
flex: 1; overflow: hidden;
transition: .5s ease-out;
cursor: pointer;
}
.actions img:hover{
flex: 3;
}
이미지로 실험해보면 아래와 같이 재미난 효과를 만들수 있다.
object-fit: cover 와 object-position: center 를 적용하면 사진이 중앙위치에서 확대된다.
.actions img{
flex: 1;
transition: .5s ease-out;
cursor: pointer;
object-fit: cover;
object-position: center;
}
헤더와 푸터는 고정값(flex-basis나 width 나 max-width)으로 잡고 메인에 flex:auto를 주면 calc로 계산하지 않고도 헤더와 푸터를 제외한 나머지 영역을 메인이 차지한다.
'프론트엔드 > HTML & CSS 강의' 카테고리의 다른 글
테이블 연습 심화과제 (0) | 2024.02.04 |
---|---|
CSS 변수와 함수 (0) | 2023.06.26 |
4. 박스모델 (Box Model) (0) | 2023.06.15 |
3. 선택자 (0) | 2023.06.12 |
2. 색상과 단위 (0) | 2023.06.12 |