프론트엔드/HTML & CSS 강의

플럭스박스(flexbox) 활용

syleemomo 2023. 6. 24. 09:23
728x90

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

 

7. 유동 너비 박스

...

codepen.io

컨테이너가 줄어들면서 아이템의 컨텐츠가 잘리면서 점(.)으로 표시되는 레이아웃을 만들어보자!

<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

 

칼럼 (Column) 레이아웃

* 칼렘 레이아웃 예시 포토1 포토2 포토3 포토4 포토5 포토6 포토7 포토8 포토9 포토10 포토11 포토12 포토13 포토14 포토15 포토16 포토17 포토18 포토19 포토20 포토21 포토21 포토23 포토24 포토25 포토26

syleemomo.tistory.com

 

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로 계산하지 않고도 헤더와 푸터를 제외한 나머지 영역을 메인이 차지한다.  

 

728x90

'프론트엔드 > 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