JQuery 시작하기

  • 1) jQuery 란?
    • HTML의 요소들을 조작하는, 편리한 Javascript를 미리 작성해둔 것. 라이브러리! 👉 Javascript로도 모든 기능(예 - 버튼 글씨 바꾸기 등)을 구현할 수는 있지만, 1) 코드가 복잡하고, 2) 브라우저 간 호환성 문제도 고려해야해서, **j**Query라는 라이브러리가 등장하게 되었답니다.
    • jQuery와 Javascript - 코드 비교해보기 👉 jQuery는 Javascript와 다른 특별한 소프트웨어가 아니라 미리 작성된 Javascript 코드입니다. 전문 개발자들이 짜둔 코드를 잘 가져와서 사용하는 것임을 기억해주세요! (그렇게 때문에, 쓰기 전에 "임포트"를 해야합니다!) Javascript로 길고 복잡하게 써야 하는 것을 ```jsx document.getElementById("element").style.display = "none"; ``` jQuery로 보다 직관적으로 쓸 수 있어요. 편리하죠? :-) ```jsx $('#element').hide(); ```
  • 2) jQuery 사용하기
    • 미리 작성된 Javascript 코드를 가져오는 것을 '임포트'라고 부릅니다.
    • jQuery를 사용하는 방법 👉 css와 마찬가지로, jQuery를 쓸 때에도 "가리켜야" → 조작할 수 있습니다. 예) 특정 인풋박스의 값을 → 가져와줘! 예) 특정 div를 → 안보이게 해줘! css에서는 선택자로 class를 썼지요? jQuery에서는 id 값을 통해 특정 버튼/인풋박스/div/.. 등을 가리키게 됩니다. 백문이불여일견! 자주 쓰는 jQuery들을 함께 다뤄보면서 익혀보죠!

03. JQuery 다뤄보기

  • 1) 자주쓰는 jQuery들 다뤄보기
    • 들어가기 전에 - 모든 jQuery를 외워야 하나요? 👉 절대!! 아닙니다. 예를 들어 스크롤 움직임을 감지한다거나, 화면 사이즈를 안다거나, jQuery가 할 수 있는 일은 무척 많습니다. 그러니, 필요할 때에 필요한 기능을 구글링해서 쓰면 되는 거예요!
    • [코드] 완성본
      <!doctype html>
      <html lang="en">
      
      <head>
          <meta charset="utf-8">
          <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
      
          <link href="https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css" rel="stylesheet"
                integrity="sha384-EVSTQN3/azprG1Anm3QDgpJLIm9Nao0Yz1ztcQTwFspd3yD65VohhpuuCOmLASjC" crossorigin="anonymous">
          <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
          <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/js/bootstrap.bundle.min.js"
                  integrity="sha384-MrcW6ZMFYlzcLA8Nl+NtUVF0sA7MsXsP1UyJoMp4YLEuNSfAP+JcXn/tWtIaxVXM"
                  crossorigin="anonymous"></script>
      
          <title>스파르타 피디아</title>
      
          <link href="https://fonts.googleapis.com/css2?family=Gowun+Dodum&display=swap" rel="stylesheet">
      
          <style>
              * {
                  font-family: 'Gowun Dodum', sans-serif;
              }
      
              .mytitle {
                  width: 100%;
                  height: 250px;
      
                  background-image: linear-gradient(0deg, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)), url('https://movie-phinf.pstatic.net/20210715_95/1626338192428gTnJl_JPEG/movie_image.jpg');
                  background-position: center;
                  background-size: cover;
      
                  color: white;
      
                  display: flex;
                  flex-direction: column;
                  align-items: center;
                  justify-content: center;
              }
      
              .mytitle > button {
                  width: 200px;
                  height: 50px;
      
                  background-color: transparent;
                  color: white;
      
                  border-radius: 50px;
                  border: 1px solid white;
      
                  margin-top: 10px;
              }
      
              .mytitle > button:hover {
                  border: 2px solid white;
              }
      
              .mycomment {
                  color: gray;
              }
      
              .mycards {
                  margin: 20px auto 0px auto;
                  width: 95%;
                  max-width: 1200px;
              }
      
              .mypost {
                  width: 95%;
                  max-width: 500px;
                  margin: 20px auto 0px auto;
                  padding: 20px;
                  box-shadow: 0px 0px 3px 0px gray;
              }
      
              .mybtns {
                  display: flex;
                  flex-direction: row;
                  align-items: center;
                  justify-content: center;
      
                  margin-top: 20px;
              }
              .mybtns > button {
                  margin-right: 10px;
              }
          </style>
          <script>
              function hey(){
                  alert('안녕!');
              }
          </script>
      </head>
      
      <body>
      <div class="mytitle">
          <h1>내 생애 최고의 영화들</h1>
          <button onclick="hey()">영화 기록하기</button>
      </div>
      <div class="mypost">
          <div class="form-floating mb-3">
              <input type="email" class="form-control" id="floatingInput" placeholder="[email protected]">
              <label for="floatingInput">영화URL</label>
          </div>
          <div class="input-group mb-3">
              <label class="input-group-text" for="inputGroupSelect01">별점</label>
              <select class="form-select" id="inputGroupSelect01">
                  <option selected>-- 선택하기 --</option>
                  <option value="1"></option>
                  <option value="2">⭐⭐</option>
                  <option value="3">⭐⭐⭐</option>
                  <option value="4">⭐⭐⭐⭐</option>
                  <option value="5">⭐⭐⭐⭐⭐</option>
              </select>
          </div>
          <div class="form-floating">
              <textarea class="form-control" placeholder="Leave a comment here" id="floatingTextarea2"
                        style="height: 100px"></textarea>
              <label for="floatingTextarea2">코멘트</label>
          </div>
          <div class="mybtns">
              <button type="button" class="btn btn-dark">기록하기</button>
              <button type="button" class="btn btn-outline-dark">닫기</button>
          </div>
      </div>
      <div class="mycards">
          <div class="row row-cols-1 row-cols-md-4 g-4">
              <div class="col">
                  <div class="card h-100">
                      <img src="https://movie-phinf.pstatic.net/20210728_221/1627440327667GyoYj_JPEG/movie_image.jpg"
                           class="card-img-top" alt="...">
                      <div class="card-body">
                          <h5 class="card-title">영화 제목이 들어갑니다</h5>
                          <p class="card-text">여기에 영화에 대한 설명이 들어갑니다.</p>
                          <p>⭐⭐⭐</p>
                          <p class="mycomment">나의 한줄 평을 씁니다</p>
                      </div>
                  </div>
              </div>
              <div class="col">
                  <div class="card h-100">
                      <img src="https://movie-phinf.pstatic.net/20210728_221/1627440327667GyoYj_JPEG/movie_image.jpg"
                           class="card-img-top" alt="...">
                      <div class="card-body">
                          <h5 class="card-title">영화 제목이 들어갑니다</h5>
                          <p class="card-text">여기에 영화에 대한 설명이 들어갑니다.</p>
                          <p>⭐⭐⭐</p>
                          <p class="mycomment">나의 한줄 평을 씁니다</p>
                      </div>
                  </div>
              </div>
              <div class="col">
                  <div class="card h-100">
                      <img src="https://movie-phinf.pstatic.net/20210728_221/1627440327667GyoYj_JPEG/movie_image.jpg"
                           class="card-img-top" alt="...">
                      <div class="card-body">
                          <h5 class="card-title">영화 제목이 들어갑니다</h5>
                          <p class="card-text">여기에 영화에 대한 설명이 들어갑니다.</p>
                          <p>⭐⭐⭐</p>
                          <p class="mycomment">나의 한줄 평을 씁니다</p>
                      </div>
                  </div>
              </div>
              <div class="col">
                  <div class="card h-100">
                      <img src="https://movie-phinf.pstatic.net/20210728_221/1627440327667GyoYj_JPEG/movie_image.jpg"
                           class="card-img-top" alt="...">
                      <div class="card-body">
                          <h5 class="card-title">영화 제목이 들어갑니다</h5>
                          <p class="card-text">여기에 영화에 대한 설명이 들어갑니다.</p>
                          <p>⭐⭐⭐</p>
                          <p class="mycomment">나의 한줄 평을 씁니다</p>
                      </div>
                  </div>
              </div>
          </div>
      </div>
      </body>
      
      </html>
      1. input 박스의 값을 가져와보기

        <div class="form-floating mb-3">
            <input id="url" type="email" class="form-control" placeholder="[email protected]">
            <label>영화URL</label>
        </div>
        // 크롬 개발자도구 콘솔창에서 쳐보기
        // id 값이 url인 곳을 가리키고, val()로 값을 가져온다.
        $('#url').val();
        
        // 입력할때는?
        $('#url').val('이렇게 하면 입력이 가능하지만!');
      1. div 보이기 / 숨기기

        <div class="mypost" id="post-box">
            <div class="form-floating mb-3">
                <input id="url" type="email" class="form-control" placeholder="[email protected]">
                <label>영화URL</label>
            </div>
            <div class="input-group mb-3">
                <label class="input-group-text" for="inputGroupSelect01">별점</label>
                <select class="form-select" id="inputGroupSelect01">
                    <option selected>-- 선택하기 --</option>
                    <option value="1"></option>
                    <option value="2">⭐⭐</option>
                    <option value="3">⭐⭐⭐</option>
                    <option value="4">⭐⭐⭐⭐</option>
                    <option value="5">⭐⭐⭐⭐⭐</option>
                </select>
            </div>
            <div class="form-floating">
                <textarea class="form-control" placeholder="Leave a comment here" id="floatingTextarea2"
                          style="height: 100px"></textarea>
                <label for="floatingTextarea2">코멘트</label>
            </div>
            <div class="mybtns">
                <button type="button" class="btn btn-dark">기록하기</button>
                <button type="button" class="btn btn-outline-dark">닫기</button>
            </div>
        </div>
        // 크롬 개발자도구 콘솔창에 쳐보기
        // id 값이 post-box인 곳을 가리키고, hide()로 안보이게 한다.
        $('#post-box').hide();
        
        // show()로 보이게 한다.
        $('#post-box').show();
      1. 태그 내 html 입력하기
      • ~
        내에, 동적으로 html을 넣고 싶을 땐? (예를 들어, 포스팅되면 → 카드 추가)
      • 카드가 붙는 div 에 id를 추가해주는 것이 핵심!

        <div class="mycards">
            <div class="row row-cols-1 row-cols-md-4 g-4" id="cards-box">
                <div class="col">
                    <div class="card h-100">
                        <img src="https://movie-phinf.pstatic.net/20210728_221/1627440327667GyoYj_JPEG/movie_image.jpg"
                             class="card-img-top" alt="...">
                        <div class="card-body">
                            <h5 class="card-title">영화 제목이 들어갑니다</h5>
                            <p class="card-text">여기에 영화에 대한 설명이 들어갑니다.</p>
                            <p>⭐⭐⭐</p>
                            <p class="mycomment">나의 한줄 평을 씁니다</p>
                        </div>
                    </div>
                </div>
            </div>
        </div>

        1) 버튼을 넣어보기

        let temp_html = `<button>나는 추가될 버튼이다!</button>`;
        $('#cards-box').append(temp_html);

        2) 버튼 말고, 카드를 넣어보기

        // 주의: 홑따옴표(')가 아닌 backtick(`)으로 감싸야 합니다.
        // 숫자 1번 키 왼쪽의 버튼을 누르면 backtick(`)이 입력됩니다.
        // backtick을 사용하면 문자 중간에 Javascript 변수를 삽입할 수 있습니다.
        let title = '영화 제목이 들어갑니다';
        
        let temp_html = `<div class="col">
        				            <div class="card h-100">
        				                <img src="https://movie-phinf.pstatic.net/20210728_221/1627440327667GyoYj_JPEG/movie_image.jpg"
        				                     class="card-img-top" alt="...">
        				                <div class="card-body">
        				                    <h5 class="card-title">${title}</h5>
        				                    <p class="card-text">여기에 영화에 대한 설명이 들어갑니다.</p>
        				                    <p>⭐⭐⭐</p>
        				                    <p class="mycomment">나의 한줄 평을 씁니다</p>
        				                </div>
        				            </div>
        				        </div>`;
        $('#cards-box').append(temp_html);

04. JQuery 적용하기(포스팅 박스)

    • (1) 완성된 모습 먼저 보기 '영화 기록하기' 버튼을 누르면 숨겨진 창이 나타나고, '닫기'를 누르면 없어집니다.
    • (2) 포스팅 박스 열기 버튼에 function을 달기
      function open_box(){
          alert('열린다!')
      }
      function close_box(){
          alert('닫힌다!')
      }
      
      <button onclick="open_box()">영화 기록하기</button>
      
      <button onclick="close_box()" type="button" class="btn btn-outline-dark">닫기</button>
      
    • (3) 클릭 해서 포스팅 박스를 여닫게 하기
      • 포스팅 박스에 id 값을 주기 (이미 가지고 있음!)
        영화URL
        별점 -- 선택하기 -- ⭐ ⭐⭐ ⭐⭐⭐ ⭐⭐⭐⭐ ⭐⭐⭐⭐⭐
        코멘트
        기록하기 닫기
      • 포스팅 박스 제어하기 function open_box(){
        $('#post-box').show()
        }
        function close_box(){
        $('#post-box').hide()
        }
      • post-box를 시작부터 감춰두기 (css의 display:none 속성!) .mypost {
        width: 95%;
        max-width: 500px;
        margin: 20px auto 0px auto;
        padding: 20px;
        box-shadow: 0px 0px 3px 0px gray;
          display: none;
        }
    • (4) 완성코드
        <!doctype html>
        <html lang="en">
        
        <head>
            <meta charset="utf-8">
            <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
        
            <link href="https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css" rel="stylesheet"
                  integrity="sha384-EVSTQN3/azprG1Anm3QDgpJLIm9Nao0Yz1ztcQTwFspd3yD65VohhpuuCOmLASjC" crossorigin="anonymous">
            <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
            <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/js/bootstrap.bundle.min.js"
                    integrity="sha384-MrcW6ZMFYlzcLA8Nl+NtUVF0sA7MsXsP1UyJoMp4YLEuNSfAP+JcXn/tWtIaxVXM"
                    crossorigin="anonymous"></script>
        
            <title>스파르타 피디아</title>
        
            <link href="https://fonts.googleapis.com/css2?family=Gowun+Dodum&display=swap" rel="stylesheet">
        
            <style>
                * {
                    font-family: 'Gowun Dodum', sans-serif;
                }
        
                .mytitle {
                    width: 100%;
                    height: 250px;
        
                    background-image: linear-gradient(0deg, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)), url('https://movie-phinf.pstatic.net/20210715_95/1626338192428gTnJl_JPEG/movie_image.jpg');
                    background-position: center;
                    background-size: cover;
        
                    color: white;
        
                    display: flex;
                    flex-direction: column;
                    align-items: center;
                    justify-content: center;
                }
        
                .mytitle > button {
                    width: 200px;
                    height: 50px;
        
                    background-color: transparent;
                    color: white;
        
                    border-radius: 50px;
                    border: 1px solid white;
        
                    margin-top: 10px;
                }
        
                .mytitle > button:hover {
                    border: 2px solid white;
                }
        
                .mycomment {
                    color: gray;
                }
        
                .mycards {
                    margin: 20px auto 0px auto;
                    width: 95%;
                    max-width: 1200px;
                }
        
                .mypost {
                    width: 95%;
                    max-width: 500px;
                    margin: 20px auto 0px auto;
                    padding: 20px;
                    box-shadow: 0px 0px 3px 0px gray;
        
                    display: none;
                }
        
                .mybtns {
                    display: flex;
                    flex-direction: row;
                    align-items: center;
                    justify-content: center;
        
                    margin-top: 20px;
                }
                .mybtns > button {
                    margin-right: 10px;
                }
            </style>
            <script>
                function open_box(){
                    $('#post-box').show()
                }
                function close_box(){
                    $('#post-box').hide()
                }
            </script>
        </head>
        
        <body>
        <div class="mytitle">
            <h1>내 생애 최고의 영화들</h1>
            <button onclick="open_box()">영화 기록하기</button>
        </div>
        <div class="mypost" id="post-box">
            <div class="form-floating mb-3">
                <input id="url" type="email" class="form-control" placeholder="[email protected]">
                <label>영화URL</label>
            </div>
            <div class="input-group mb-3">
                <label class="input-group-text" for="inputGroupSelect01">별점</label>
                <select class="form-select" id="inputGroupSelect01">
                    <option selected>-- 선택하기 --</option>
                    <option value="1"></option>
                    <option value="2">⭐⭐</option>
                    <option value="3">⭐⭐⭐</option>
                    <option value="4">⭐⭐⭐⭐</option>
                    <option value="5">⭐⭐⭐⭐⭐</option>
                </select>
            </div>
            <div class="form-floating">
                <textarea id="comment" class="form-control" placeholder="Leave a comment here" id="floatingTextarea2"
                          style="height: 100px"></textarea>
                <label for="floatingTextarea2">코멘트</label>
            </div>
            <div class="mybtns">
                <button type="button" class="btn btn-dark">기록하기</button>
                <button onclick="close_box()" type="button" class="btn btn-outline-dark">닫기</button>
            </div>
        </div>
        <div class="mycards">
            <div class="row row-cols-1 row-cols-md-4 g-4" id="cards-box">
                <div class="col">
                    <div class="card h-100">
                        <img src="https://movie-phinf.pstatic.net/20210728_221/1627440327667GyoYj_JPEG/movie_image.jpg"
                             class="card-img-top" alt="...">
                        <div class="card-body">
                            <h5 class="card-title">영화 제목이 들어갑니다</h5>
                            <p class="card-text">여기에 영화에 대한 설명이 들어갑니다.</p>
                            <p>⭐⭐⭐</p>
                            <p class="mycomment">나의 한줄 평을 씁니다</p>
                        </div>
                    </div>
                </div>
                <div class="col">
                    <div class="card h-100">
                        <img src="https://movie-phinf.pstatic.net/20210728_221/1627440327667GyoYj_JPEG/movie_image.jpg"
                             class="card-img-top" alt="...">
                        <div class="card-body">
                            <h5 class="card-title">영화 제목이 들어갑니다</h5>
                            <p class="card-text">여기에 영화에 대한 설명이 들어갑니다.</p>
                            <p>⭐⭐⭐</p>
                            <p class="mycomment">나의 한줄 평을 씁니다</p>
                        </div>
                    </div>
                </div>
                <div class="col">
                    <div class="card h-100">
                        <img src="https://movie-phinf.pstatic.net/20210728_221/1627440327667GyoYj_JPEG/movie_image.jpg"
                             class="card-img-top" alt="...">
                        <div class="card-body">
                            <h5 class="card-title">영화 제목이 들어갑니다</h5>
                            <p class="card-text">여기에 영화에 대한 설명이 들어갑니다.</p>
                            <p>⭐⭐⭐</p>
                            <p class="mycomment">나의 한줄 평을 씁니다</p>
                        </div>
                    </div>
                </div>
                <div class="col">
                    <div class="card h-100">
                        <img src="https://movie-phinf.pstatic.net/20210728_221/1627440327667GyoYj_JPEG/movie_image.jpg"
                             class="card-img-top" alt="...">
                        <div class="card-body">
                            <h5 class="card-title">영화 제목이 들어갑니다</h5>
                            <p class="card-text">여기에 영화에 대한 설명이 들어갑니다.</p>
                            <p>⭐⭐⭐</p>
                            <p class="mycomment">나의 한줄 평을 씁니다</p>
                        </div>
                    </div>
                </div>
            </div>
        </div>
        </body>
        
        </html>

좋은 웹페이지 즐겨찾기