11일코딩완주챌린지 [2주차] 4일차

Roxy 빛나는 새벽·2021년 7월 22일
0

1. 학습내용

✔Javascript 복습하기

<script>
        let count = 1;
        function hey() {
            if (count % 2 == 0) {
                alert('짝수입니다!')
            } else {
                alert('홀수입니다!')
            }
            count += 1;          ('+=' - count + 1)
        }
    </script>코드를 입력하세요

변수를 함수안에서 넣으면 완전히 사라지지만, 변수를 함수바깥에서 해야 성립이 됨.
let count = 1이 function hey() 위에 위치함.

✔ JQuery 는 미리 작성된(남이 짜둔) Javascript의 코드! 그렇기 때문에 쓰기 전에 '임포트'를 해야 한다!!!
즉, JQuery는 Javascript에서 '임포트'한 코드에서만 작동됨.
*부트스트랩과 비슷한 맥락.
Javascript - document.getElementById("element").style.display = "none";
Jquery - $('#element').hide();

✔자주쓰는 JQuery 다뤄보기
구글 CDN 가져오기 https://www.w3schools.com/jquery/jquery_get_started.asp
1. input 박스 값을 가져와보기

<input type="email" class="form-control" id="article-url" aria-describedby="emailHelp"
                   placeholder="">

크롬개발자도구콘솔창에서 id값이 article-url지칭해서,
$('#article-url').val(); 이라고 친다.

  1. div 보이기 / 숨기기
    $('#post-box').hide(); / $('#post-box').show();

  2. css 값 가져와보기 (display 속성 값 가져와보기)

    $('#post-box').hide();
    $('#post-box').css('display');

4. 태그 내 텍스트 입력하기
> ```
<a onclick="openclose()" id="btn-posting-box" class="btn btn-primary btn-lg" href="#" role="button">포스팅박스 열기</a>

id값을 입력한다.

$('#btn-posting-box').text('포스팅 박스 닫기');
$('#btn-posting-box').text('포스팅 박스 열기');
  1. 태그 내 html 입력하기 ✅문자열html에서 (백팁)을 쓴다
<div class="card-columns" id="cards-box">

id값을 입력한다.

-[버튼 넣어보기]

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

[카드 넣어보기]

let temp_html = <div class="card">
            <img class="card-img-top"
                 src=""
                 alt="Card image cap">
            <div class="card-body">
                <a href="http://naver.com/" class="card-text"> 여기에 기사제목이 들어가죠 </a>
                <p class="card-text">기사의 요약 내용이 들어갑니다. 동해물과 백두산이 마르고 닳도록 하느님이 보우하사 우리나라만세 무궁화 삼천리 화려강산...</p>
                <p class="card-text comment">여기에 코멘트가 들어갑니다.</p>
            </div>
        </div>

즉,

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>`;

2.마지막 단계

$('#cards-box').append(temp_html);    -몇 번 누르면 나타남.

✔Jquery 적용하기

	<script>

        function openclose() { 
            let status = $(`#post-box`).css(`display`);        
            if (status == 'block') {
                $(`#post-box`).hide();
                $(`#btn-posting-box`).text('포스팅박스 열기');
            } else {
                $(`#post-box`).show();
                $(`#btn-posting-box`).text('포스팅박스 닫기');
            }
        }
    </script>
  콘솔창에서 현재상태를 알아본다. $(`#post-box`).css(`display`) -'block'
  let status = $(`#post-box`).css(`display`);
  	console.log(status);                  -콘솔창에서 'block'이라고 뜨는지 확인
  if (status == 'block') {
                $(`#post-box`).hide();
            } else {
                $(`#post-box`).show();
            }                    이라고 만든다음에 hide와 show를 바꿔저도 상관없음.
  id값이 btn-posting-box이기 때문에
  $(`#btn-posting-box`).text('포스팅박스 열기');
  $(`#btn-posting-box`).text('포스팅박스 닫기');   추가함.

✔Jquery 연습하기 (퀴즈)
1. 빈칸 체크 함수 만들기

function q1() {
            let txt = $('#input-q1').val();
            if (txt =='') {
              alert('입력하세요!')
            } else {
              alert(txt)
            }
        // 1. input-q1의 입력값을 가져온다. $('# .... ').val() 이렇게!
        // 2. 만약 입력값이 빈칸이면 if(입력값=='')
        // 3. alert('입력하세요!') 띄우기
        // 4. alert(입력값) 띄우기
    }
  function q1() {
            let txt = $('#input-q1').val();
  				console.log(txt)      
  입력값과 콘솔창에서 나타내는 값이 잘 나오는지 확인.
  마지막으로 완성한 뒤에도 입력값과 얼럿창 잘 나오는지 확인.

2. 이메일 판별 함수 만들기
> ```
function q2() {
            let txt = $('#input-q2').val();
            console.log(txt.includes('@'))

            if (txt.includes('@')) {
              let domain = txt.split(`@`)[1].split(`.`)[0]
              alert(domain)
            } else {
              alert('이메일이 아닙니다')
           }

            // 1. input-q2 값을 가져온다.
            // 2. 만약 가져온 값에 @가 있으면 (includes 이용하기 - 구글링!) - > javascript 문자열 포함 체크 라고 구글링 즉,txt.includes('@') 라고 입력할 것.
            // 3. info.spartacoding@gmail.com -> gmail 만 추출해서 ( .split('@') 을 이용하자!) -> ✅먼저, 콘솔창에서 이메일추출연습해서 값을 가져오기 let domain = txt.split(`@`)[1].split(`.`)[0] 라고 입력할 것.
            // 4. alert(도메인 값);으로 띄우기
            // 5. 만약 이메일이 아니면 '이메일이 아닙니다.' 라는 얼럿 띄우기
        }

✅ 콘솔창에서 미리 만들기
let txt= 'sparta@naver.com'
undefined
let txt= sparta@naver.com
undefined
txt.split(@)
(2) ["sparta", "naver.com"]
txt.split(@)[1]
"naver.com"
txt.split(@)[1].split(.)
(2) ["naver", "com"]
txt.split(@)[1].split(.)[0]
"naver"

  1. HTML 붙이기 연습

    function q3() {
                let txt = $('#input-q3').val();
                let temp_html =`<li>${txt}</li>`     

    $('#names-q3').append(temp_html)

            // 1. input-q3 값을 가져온다. let txt = ... q1, q2에서 했던 걸 참고!
            // 2. 가져온 값을 이용해 names-q3에 붙일 태그를 만든다. (let temp_html = <li>임꺽정</li>  -> `<li>${txt}</li>`) 요렇게!   console.log(temp_html)넣은 후 콘솔창 확인!
            // 3. 만들어둔 temp_html을 names-q3에 붙인다.(jQuery의 $('...').append(temp_html)을 이용하면 굿!)
        }

4. HTML 지우기 연습
> ```
function q3_remove() {
           $('#names-q3').empty()

            // 1. names-q3의 내부 태그를 모두 비운다.(jQuery의 $('....').empty()를 이용하면 굿!)
        }

✔ Ajax 이해하기 전
서버-클라이언트 사이의 창구 즉, API라고 칭함.
서버가 클라이언트에게 내려주는 포맷을 JSON이라고 함.
클라이언트가 서버에게 요청할 때 'GET' / 'POST'가 존재함.
https://movie.naver.com/movie/bi/mi/basic.naver?code=161967&name=sparta
-서버주소: https://movie.naver.com
-은행창구이름: movie/bi/mi/basic.naver
-가지고 가는 데이터값: code=161967
-전달할 데이터가 있다(창구외에 오류지만, 상관없는 데이터일뿐): name=sparta

✔ Ajax는 Jquery를 '임포트'한 페이지에서만 작동됨.
[코드해설]

$.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",
  url: "http://openapi.seoul.go.kr:8088/6d4d776b466c656533356a4b4b5872/json/RealtimeCityAir/1/99",
  data: {},
  success: function(response){
    console.log(response[`RealtimeCityAir`][`row`][0])
  }
})

2. 학습소감

Javascript와 JQuery 1주차에서 배웠던 것부터 JQuery적용까지 한번 더 복습하니 쭈욱 이해가 된다.
다음시간에는 Ajax API ㄱㄱ~
ps.이 개발블로그에 코드입력이용하기가 힘들다ㅠㅠ

profile
신입개발자가 되기 위한 노력 프로젝트

0개의 댓글