간단한 애니메이션 만들기

✨ 과제. 버튼 누르면 modal 창 띄우기 (jQuery 사용하기)

main.css
.black-bg{
    display: none;
}
.show-modal{
    display: block;
}
<script>
    $('#loginBtn').on('click', function(){
        $('.black-bg').toggleClass('show-modal');
        $('.black-bg').addClass('show-modal');
     });

     $('#close').on('click', function() {
        $('.black-bg').toggleClass('show-modal');
        $('.black-bg').removeClass('show-modal');
     })
</script>

💎간단한 애니메이션 만들기

지난번 UI 만들기는 이런 프로세스로 만들었다.

1. HTML / CSS로 미리 디자인

2.필요할 때 호출

애니메이션은

1. 시작 스타일 만들기 (class)

2. 최종 스타일 만들기 (class)

3. 원할 때 최종스타일로 변하라고 JS 코드 짜기

4. 시작스타일에 transition 추가

js007.html을 복사해 js008.html 만들기

js008.html
<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>Bootstrap demo</title>

    <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.1/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-4bw+/aepP/YC94hEpVNVgiZdgIC5+VKNBQNGCHeKRQN+PtmoHDEXuppvnDJzQIu9" crossorigin="anonymous">

    <link rel="stylesheet" href="main.css">
    <script src="https://code.jquery.com/jquery-3.7.0.min.js" integrity="sha256-2Pmvv0kuTBOenSvLm6bvfBSSHrUJ+3A7x6P5Ebd07/g=" crossorigin="anonymous"></script>

</head>
<body>

    <div class="black-bg1">
        <div class="white-bg">
            <h4>로그인하세요</h4>
            <button class="btn btn-danger" id="close">닫기</button>
        </div>
    </div>

    <nav class="navbar ">
        <div class="container-fluid">
            <a class="navbar-brand" href="#">Offcanvas navbar</a>
            <button class="navbar-toggler" type="button">
                <span class="navbar-toggler-icon"></span>
            </button>
        </div>
    </nav>

    <ul class="list-group" id="list1">
        <li class="list-group-item">An item</li>
        <li class="list-group-item">A second item</li>
        <li class="list-group-item">A third item</li>
        <li class="list-group-item">A fourth item</li>
        <li class="list-group-item">And a fifth one</li>
    </ul>

    <button id="loginBtn" type="button" class="btn btn-primary">
        버튼
    </button>

  
    <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.1/dist/js/bootstrap.bundle.min.js" integrity="sha384-HwwvtgBNo3bZJJLYd8oVXjrBZt8cqVSpeBNS5n7C8IVInixGAoxmnlMuBnhbgrkm" crossorigin="anonymous"></script>
</body>
</html>

black-bg 클래스를 black-bg1 클래스로 변경하고 css 추가

main.css
.black-bg1 {
    width : 100%;
    height : 100%;
    position : fixed;
    background : rgba(0,0,0,0.5);
    z-index : 5;
    padding: 30px;
    visibility: hidden;
    opacity: 0;
}

.show-modal1 {
    visibility: visible;
    opacity: 1;
}

이렇게 1.시작스타일2.최종스타일을 작성함

기존의 display는 애니메이션이 잘 동작하지 않기 때문에

비슷한 역할을 하는 visibility: hidden 을 사용함

opacity는 투명도 조절 속성 (0은 투명 1은 불투명) 0과 1사이의 값으로 투명도 조절 가능

3. 원할 때 최종스타일로 변하라고 JS 코드 짜기

  <script>
     $('#loginBtn').on('click', function(){
        $('.black-bg1').addClass('show-modal1');

     });

     $('#close').on('click', function() {
        $('.black-bg1').removeClass('show-modal1');
     })
 </script>

4. 시작스타일에 transition 추가

.black-bg1 {
    width : 100%;
    height : 100%;
    position : fixed;
    background : rgba(0,0,0,0.5);
    z-index : 5;
    padding: 30px;
    visibility: hidden;
    opacity: 0;
    transition: all 5s;
}

transition의 시간을 조절해서 애니메이션 길이 변경 가능

✨ 실습. 기존에 만들었던 navbar를 애니메이션을 사용해 아래로 펼쳐지게 만들어보자.

.list-group {
    height: 0;
    overflow: hidden;
    transition: height 2s;
}
.lg-open{
    height: 250px;
}
<script>
    $('.navbar-toggler').on('click', function() {
        $('.list-group').toggleClass('lg-open');
    });
</script>

Last updated