티스토리 뷰

Web/CSS

Making a responsive slider with SCSS

고기상추밥 2019. 11. 30. 18:22

Intro

We are going to create a slider that automatically adjusts animation keyframes based on number of items to rotate through items, using only HTML5 and SCSS. Below example demonstrates desired outcome.

 

Breakdown

Let's make make our initial HTML structure as following.

// .scene is a wrapper for .slider
<div class="scene">
   // .slider contains all the items.
  <div class="slider">
    // .item selects each item
    // Duplicate the first item, then append it to the end
    // to generate infinite animation effect.
    <div class="item item-1">1</div>
    <div class="item item-2">2</div>
    <div class="item item-3">3</div>
    <div class="item item-1">1</div>
  </div>
</div>

 

Let's style it with SCSS as following,

// background color for slider and each items
$slider:#FFF493;
$primary:#87E892;
$secondary:#A1E3FF;
$tertiary:#B187E8;

// Store each color to SCSS list
$color-list: $primary, $secondary, $tertiary;

// Total number of items
$total: 3;
// $total + extra .item
$total-extra: $total + 1;

// Use max-width to make it responsive
// Set appropriate height
// Set overflow to hidden to hide overflowing portion of .slider
.scene{
  max-width:300px;
  height:150px;
  overflow:hidden;
}

// Set background-color using scss variable, which is declared at the top.
// Set display to flex to align elements to horizon axis
// Set width to 100%, it means 100% of the width of parent, which is width of .scene in this case.
// Multiply width by $total-extra
// Set height to 100% to match the height of parent.
.slider {
  background-color: $slider;
  display: flex;
  width: 100% * $total-extra;
  height: 100%;
}

// Set flex to 1 to divide width of each .item equally. 
// Set font-size to appropriate size.
// set color to #fff.
// Rest properties are for centering text
.item{
  flex:1;
  font-size:2rem;
  color:#fff;
  display:flex;
  justify-content:center;
  align-items:center;
}

// Use SCSS @for loop to assign each color in $color-list to each .item.
@for $i from 1 through $total{
  .item-#{$i}{
    background-color: nth($color-list, $i);
  }
}

 

When flex on .slider and overflow on .scene are not used, it would look like this in the browser.

Set display on .scene to flex, it would look like this in the browser.

Set overflow to hidden to hide overflowing portion of .scene, it looks like this in the browser.

Let's set @keyframes to make slider iterate itself.

// .slider will translate by amount of $translate
// @keyframes slider has two phase pause and slide
// pause phase will have 90% fo total time, and slide phase will have 10% of total time.
// $pause is time required for .item to be paused
// $slide is time required for .item to slide
// $current will stack value of keyframes during iteration.
$translate: 100% / $total-extra;
$pause: 90% / ($total);
$slide: 10% / ($total);
$current: 0%;
@keyframes slider {
  @for $i from 1 through $total {
    // start phase
    @if $i - 1 == 0 {
      #{$current} {
        transform: translateX(0);
      }
    }
    
    // config pause phase
    $current: $current + $pause !global;
    #{$current} {
      transform: translateX($translate * -($i - 1));
    }

    // config slide phase
    @if $i < $total {
      $current: $current + $slide !global;
      #{$current} {
        transform: translateX($translate * -$i);
      }
       // end phase
    }  @else {
      100% {
        transform: translateX($translate * -$i);
      }
    }
  }
}

 

Conclusion

When new .item is appended to .slider, configuring $total will generate @keyframes accordingly.

CodePen

See the Pen Responsive Slider by thesoundfromthesky (@thesoundfromthesky) on CodePen.

 

 

'Web > CSS' 카테고리의 다른 글

SCSS 이용하여 반응형 슬라이더 구현하기  (0) 2019.11.30
CSS 요약  (0) 2018.12.02
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/01   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
글 보관함