티스토리 뷰

항해

2주차_8(Ajax시작하기=jquery)

타올이 2021. 12. 7. 21:55
반응형

Ajax 시작하기

  ※절대 이해하려하지말고 갖다쓰기~~~!

크롬 개발자 도구에 다음과 같이 써보세요

참고! Ajax는 jQuery를 임포트한 페이지에서만 동작 가능합니다.

즉, http://google.com/ 과 같은 화면에서 개발자도구를 열면,

jQuery가 임포트 되어있지 않기 때문에 아래와 같은 에러가 뜹니다.

Uncaught TypeError: $.ajax is not a function

→ ajax라는 게 없다는 뜻

[코드스니펫] 미세먼지 OpenAPI

http://openapi.seoul.go.kr:8088/6d4d776b466c656533356a4b4b5872/json/RealtimeCityAir/1/99

[코드스니펫] Ajax 기본 골격

$.ajax({

   type: "GET",

   url: "여기에URL을입력",

   data: {},

    success: function(response){

        console.log(response)

     }

})

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 코드 설명

  • type: "GET" → GET 방식으로 요청한다.
  • url: 요청할 url
  • data: 요청하면서 함께 줄 데이터 (GET 요청시엔 비워두세요)

리마인드

GET 요청은, url뒤에 아래와 같이 붙여서 데이터를 가져갑니다.

http://naver.com?param=value¶m2=value2

 

POST 요청은, data : {} 에 넣어서 데이터를 가져갑니다.

data: { param: 'value', param2: 'value2' },

  • success: 성공하면, response 값에 서버의 결과 값을 담아서 함수를 실행한다.

결과가 어떻게 response에 들어가나요? → 받아 들이셔야 합니다..!

(대부분의 개발자들도 내부 원리는 코드를 안 뜯어봐서 몰라요.^^;;)

success: function(response){ // 서버에서 준 결과를 response라는 변수에 담음

     console.log(response)

}

수업

1.url 주소가져오기

$.ajax({
  type: "GET",
  url: "http://openapi.seoul.go.kr:8088/6d4d776b466c656533356a4b4b5872/json/RealtimeCityAir/1/99",
  data: {},
  success: function(response){
    console.log(response)
  }
})

2.상세하게 가져오기

$.ajax({
  type: "GET",
  url: "http://openapi.seoul.go.kr:8088/6d4d776b466c656533356a4b4b5872/json/RealtimeCityAir/1/99",
  data: {},
  success: function(response){
    console.log(response['RealtimeCityAir']['row'][0])
  }
})

3.반복문 돌리기

$.ajax({
  type: "GET",
  url: "http://openapi.seoul.go.kr:8088/6d4d776b466c656533356a4b4b5872/json/RealtimeCityAir/1/99",
  data: {},
  success: function(response){
    let rows = response['RealtimeCityAir']['row']
    for (let i=0; i< rows.length; i++) {
        let gu_name = rows[i]['MSRSTE_NM']
        let gu_mise = rows[i]['IDEX_MVL']
        console.log(gu_name,gu_mise)
    }
  }
})

4.if추가

$.ajax({
  type: "GET",
  url: "http://openapi.seoul.go.kr:8088/6d4d776b466c656533356a4b4b5872/json/RealtimeCityAir/1/99",
  data: {},
  success: function(response){
    let rows = response['RealtimeCityAir']['row']
    for (let i=0; i< rows.length; i++) {
        let gu_name = rows[i]['MSRSTE_NM']
        let gu_mise = rows[i]['IDEX_MVL']
      if (gu_mise<70) {
    console.log(gu_name,gu_mise)
      } 
    }
  }
})

반응형

'항해' 카테고리의 다른 글

3주차_2(연습 겸 복습 수업)  (0) 2021.12.10
3주차_1(연습 겸 복습)  (0) 2021.12.10
2주차_7(서버-클라이언트 통신 이해하기)  (0) 2021.12.07
jQuery 퀴즈-2주차  (0) 2021.12.07
2주차_6(jQuery다뤄보기4)  (0) 2021.12.07
반응형
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
«   2024/12   »
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
링크
글 보관함