[jQuery] jQuery가 뭐야!

영은히히·2022년 1월 13일
0
post-thumbnail

📌 공부할 것 : Javascript로 다시 서버에 데이터를 요청하고 받는 방법

jQuery를 이용해 Javascript로 HTML을 제어하고,
Ajax를 이용해 다시 서버에 데이터를 요청하고 받아오겠다.


📖 JQuery

: HTML의 요소들을 조작하는, 편리한 Javascript를 미리 작성해둔 것. 라이브러리!
: 즉, 미리 작성된 Javascript 코드이다 -> !import 필수!

-> Javascript로도 모든 기능(예 - 버튼 글씨 바꾸기 등)을 구현할 수는 있지만,
1) 코드가 복잡하고, 2) 브라우저 간 호환성 문제도 고려해야해서,
jQuery라는 라이브러리 등장하였다
  • 코드 비교
// javascript
document.getElementById("element").style.display = "none";
// jQuery
$('#element').hide();

<head>와 </head> 사이에 jQuery CDN부분 임포트 하기!

👉 css와 마찬가지로, jQuery를 쓸 때에도 "가리켜야" → 조작할 수 있다
예) 특정 인풋박스의 값을 → 가져와!
예) 특정 div를 → 안보이게 해!

css에서는 선택자로 class를 썼다면,
jQuery에서는 **id 값**을 통해 특정 버튼/인풋박스/div/.. 등을 가리키게 된다

💻 input 박스의 값을 가져와보장

<<div class="posting-box">
    <div class="form-group">
        <label for="exampleInputEmail1">아티클 URL</label>
        <input id="post-url" type="email" class="form-control" aria-describedby="emailHelp"
            placeholder="">
    </div>
    <div class="form-group">
        <label for="exampleInputPassword1">간단 코멘트</label>
        <input type="password" class="form-control" placeholder="">
    </div>
    <button type="submit" class="btn btn-primary">기사 저장</button>
</div>
// 크롬 개발자도구 콘솔창에서 쳐보기
// id 값이 post-url인 곳을 가리키고, val()로 값을 가져온다.
$('#post-url').val();

.val()은 양식(form)의 값을 가져오거나 값을 설정하는 메소드다.

<문법>
$("선택자").val();
$("선택자").val("속성");
$("선택자").val("함수");

💻 div 보이기/숨기기

<div class="posting-box" id="post-box">
    <div class="form-group">
        <label for="exampleInputEmail1">아티클 URL</label>
        <input id="post-url" type="email" class="form-control" aria-describedby="emailHelp"
            placeholder="">
    </div>
    <div class="form-group">
        <label for="exampleInputPassword1">간단 코멘트</label>
        <input type="password" class="form-control" placeholder="">
    </div>
    <button type="submit" class="btn btn-primary">기사 저장</button>
</div>
// 크롬 개발자도구 콘솔창에 쳐보기
// id 값이 post-box인 곳을 가리키고, hide()로 안보이게 한다.(=css의 display 값을 none으로 바꾼다)
$('#post-box').hide();

// show()로 보이게 한다.(=css의 display 값을 block으로 바꾼다)
$('#post-box').show();

💻 css 값 가져오기


$('#post-box').css('display');
보이면 block 상태
안보이면 none 상태

.css()는 선택한 요소의 css 속성값을 가져오거나 style 속성을 추가한다

💻 태그 내 텍스트 입력하기

-> input box일 때

$('#post-url').val('여기에 텍스트를 입력하면!');

-> 다른 것들 예)버튼의 텍스트 내용 바꾸기


// 가리키고 싶은 버튼에 id 값을 준다음
<button id="btn-posting-box" type="button" class="btn btn-primary">포스팅 박스 열기</button>
$('#btn-posting-box').text('포스팅 박스 닫기');

💻 태그 내 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);
profile
어차피 알아야 한다. 한 번에 하자

0개의 댓글