1. Javascript 복습

  • onclick 함수
    - 짝/홀수에 따라 다른 얼럿 띄우는 onclick 함수 함께 만들어보기
    Count += 1; 는 count = count + 1; 와 같다.
    하지만 변수를 함수 안에서 선언해서 쓰면 함수가 끝나면서 자동으로 사라져 웹에서 alert가 제대로 작동하지 않는다.
    변수를 함수 위로 빼면 함수와 상관없이 어디서든 script 안에서 써먹을 수 있다.
    웹에서 포스팅박스 열기 버튼 클릭 시 제대로 작동한다.

2. JQuery

  • HTML의 요소들을 조작하는, 편리한 Javascript를 미리 작성해둔 것. 라이브러리!
  • 미리 작성된 Javascript 코드이므로 쓰기 전에 "임포트"를 해야합니다!
    Javascript로 길고 복잡하게 써야 하는 것을
document.getElementById("element").style.display = "none";
jQuery로 보다 직관적으로 쓸 수 있어요. 편리하죠? :-)
$('#element').hide();
  • JQuery 다뤄보기
    - 미리 작성된 Javascript 코드를 가져오는 것을 '임포트'라고 부릅니다. jQuery CDN
    - < head >와 < /head > 사이에 넣어서 쓴다.
    - css에서는 선택자로 class를 썼지요?
    jQuery에서는 id 값을 통해 특정 버튼/인풋박스/div/.. 등을 가리키게 됩니다.
  • Input 박스 값 가져오기
    id값: article-url
    $('#article-url').val();으로 입력 시 아티클 URL 하단 칸에 세종대왕으로 입력된다. $('#article-url').val('장영실'); 입력 시 아티클 URL 하단 칸에 장영실으로 변경된다.
    id에 input박스 value를 가져오는 것. 참고로 .은 뒤에 오는 값에 접근한다는 뜻.
    그리고 $('#') ''안에 # 빼먹지 말자. 실제 코딩하면서 실수가 잦았다.
  • div 보이기 / 숨기기
$('#post-box').hide();
$('#post-box').show();
  • css의 값 가져와보기
$('#post-box').hide();
$('#post-box').css('display');

$('#post-box').show();
$('#post-box').css('display');
  • 태그 내 텍스트 입력하기
$('#post-url').val('여기에 텍스트를 입력하면!');
  • 버튼의 텍스트 바꾸기
// 가리키고 싶은 버튼에 id 값을 준다음
<button id="btn-posting-box" type="button" class="btn btn-primary">포스팅 박스 열기</button>
$('#btn-posting-box').text('포스팅 박스 닫기');
  • < div > ~ < /div > 내에,동적으로 html을 넣고 싶을 땐?
    < div > ~ < /div > 내에,
    동적으로 html을 넣고 싶을 땐? (예를 들어, 포스팅되면 → 카드 추가)
// 사이에 html을 넣고 싶은 태그에 id값을 준 다음
<div id="cards-box" class="card-columns">
    <div class="card">
      <img class="card-img-top" src="https://www.fodors.com/wp-content/uploads/2018/10/4_UltimateRome_PiazzaNavona-975x650.jpg" alt="Card image cap">
      <div class="card-body">
        <a href="https://naver.com/" class="card-title">여기 기사 제목이 들어가죠</a>
        <p class="card-text">여기에 기사 내용이 들어가겠죠</p>
        <p class="card-text comment">여기엔 코멘트가 들어갑니다</p>
      </div>
    </div>
  </div>

1) 버튼을 넣어보기

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

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

// 주의: 홑따옴표(')가 아닌 backtick(`)으로 감싸야 합니다.
// 숫자 1번 키 왼쪽의 버튼을 누르면 backtick(`)이 입력됩니다.
// backtick을 사용하면 문자 중간에 Javascript 변수를 삽입할 수 있습니다.
let img_url = 'https://www.eurail.com/content/dam/images/eurail/Italy%20OCP%20Promo%20Block.adaptive.767.1535627244182.jpg';
let link_url = 'https://naver.com/';
let title = '여기 기사 제목이 들어가죠';
let desc = '기사의 요약 내용이 들어갑니다. 동해물과 백두산이 마르고 닳도록 하느님이 보우하사 우리나라만세 무궁화 삼천리 화려강산...';
let comment = '여기에 코멘트가 들어갑니다.';

let temp_html = `<div class="card">
                    <img class="card-img-top"
                        src="${img_url}"
                        alt="Card image cap">
                    <div class="card-body">
                        <a href="${link_url}" class="card-title">${title}</a>
                        <p class="card-text">${desc}</p>
                        <p class="card-text comment">${comment}</p>
                    </div>
                </div>`;
$('#cards-box').append(temp_html);

  • jQuery를 이용한 Image 태그 src변경
    $("#img_form_url(img id").attr("src", imgurl);

3. Ajax

  • 서버→클라이언트: "JSON"
  • JSON은, Key:Value로 이루어져 있습니다.
    GET→통상적으로! 데이터 조회(Read)를 요청할 때
    예) 영화 목록 조회
    POST→통상적으로! 데이터 생성(Create), 변경(Update), 삭제(Delete) 요청 할 때
    예) 회원가입, 회원탈퇴, 비밀번호 수정
  • Ajax는 jQuery를 임포트한 페이지에서만 동작 가능
  • Ajax 기본 골격
$.ajax({
  type: "GET", // GET 방식으로 요청한다.
  url: "http://openapi.seoul.go.kr:8088/6d4d776b466c656533356a4b4b5872/json/RealtimeCityAir/1/99",
  data: {}, // 요청하면서 함께 줄 데이터 (GET 요청시엔 비워두세요)
  success: function(response){ // 서버에서 준 결과를 response라는 변수에 담음
    console.log(response) // 서버에서 준 결과를 이용해서 나머지 코드를 작성
  }
})
  • Ajax 로딩 후 바로 호출하기
    $(document).ready(function() {
    ();
    });
  • 고양이OpenAPI 실습 시 이용한 코드
<script>
      function q1() {
        $.ajax({
          type: "GET",
          url: "https://api.thecatapi.com/v1/images/search",
          data: {},
          success: function(response){
              let imgurl = response[0]['url'];
              $("#img-cat").attr("src", imgurl);
            }
          })
      }
    </script>

사실 response[0] 부분에서 왜 0인지 이해가 안갔었는데, 컴퓨터는 0번째부터 정보를 불러오므로 해당 값을 넣어줘야 차례대로 출력한다고 한다.

2주차도 끝. JQuery와 Ajax 은근히 어려워서, 코드를 맞을 때 까지 계속해서 짜보았더니 조금씩 감이 온다.. 까먹지 않도록 연습 많이 해야겠다.

0개의 댓글