jQuery - 기본 문법

songmin jeon·2024년 1월 25일
0

선행작업


0. jQuery의 필요성


  • 브라우저 마다 기능을 다른 코드로 해줘야하는 불편함이 있다.
  • 크롬 : addEventLisrener 로 접근
  • 익스플러러 : attachEvent 로 접근

  • jQuery 라이브러리는 크로스브라우징 기능으로 웹 브라우저간 동등성을 제공 하여 브라우저에 대한 제약을 벗어날 수 있다 !


1. jQuery 기본 문법

  • 노랑색 영역과 빨강색 영역의 차이를 알아보자
    • 노랑색 영역 : jQuery 라이브러리를 사용하기 위해 불러옴
    • 빨강색 영역 : script 태그 내(컨턴츠 또는 내용) jQuery 문법을 작성

1.1. head 태그에 불러오기

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>

    <!-- 해당 코드가 있어야, 아래쪽에서 jQuery 문법을 작성할 수 있다. -->
    <script src="./js/jquery-3.7.1.min.js"></script>
</head>

1.2. body 태그에 적용하기

<body>

    <img src="https://lh3.googleusercontent.com/proxy/Yyqrz8WQtz0ZU9u7JDeUfZrUem-sJGH-8YPU2IORyxYGP4rvV0yNZw_5uuYfvqCBOdMTPHhts-VQzpC61CSTiy73sd9759Zsfw1OQyzuvbTIDW1Wt_UfFiM" alt="">
    <img src="" alt="">
    <img src="https://i.namu.wiki/i/5BHb2UsJISdW7UNCo_Q5Dld-BplCMkjfb81-YPIGGQYu5tN0FRzCAPpENK4eqmdPEELS4wGTCLbwnRy5waPNQQ.webp" alt="">
    <img src="https://i.namu.wiki/i/2xsBZTJ8WjEpM62TNTV9r6PpS4Tixp946ZL0R5wXa6Oz_PddaUvyAX6qDkICeYKPhiY100UD3-EvJn4oLmGqNQ.webp" alt="">
   
    <script>
        // let imgs = document.getElementsByTagName('img');
        // console.log(imgs);

        // for(let i = 0; i<imgs.length; i++){
        //     imgs[0].style.width = '100px';
        // }


        // jQeury 기본 문법
        // 1. 요소 선택하는 방법 >> $("css선택자")
        // $("css선택자"). 스타일을 여러가지 붙여서 추가할 수 있다.
        console.log($('img'));
        $('img').width('100px').height('100px');
    </script>
</body>
  • 결과


2. 문법습득

2.1. 요소 및 태그 접근

처음화면 내용 변경 클릭시
스타일 변경 클릭시 사진 변경 클릭시
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="./js/jquery-3.7.1.min.js"></script>
</head>
<body>
    <img id="pic" width="200px" src="https://i.namu.wiki/i/2xsBZTJ8WjEpM62TNTV9r6PpS4Tixp946ZL0R5wXa6Oz_PddaUvyAX6qDkICeYKPhiY100UD3-EvJn4oLmGqNQ.webp">
    <p id="pTag">나나는 메타몽 뭐든 변해요 ~ </p>
    <input type="text" id="inputTxt">
    <button id="btn">내용 변경!</button>
    <br>
    <button id="style-btn">스타일 변경</button>
    <button id="pic-btn">사진 변경</button>

    <script>
        // jQuery 문법 기호 : $

        // 1. 내가 원하는 HTML 요소를 JS에서 활용할 수 있도록 가져오기
        // v-JS : document.getElement ~
        // jQuery : $('css선택자')
        let pTag = $('#pTag');
        console.log("p태그 : ",pTag);


        // 2. 내가 원하는 요소에 내용만 가져오기
        // v-JS : .innerText
        // jQuery : .text()
        console.log("텍스트만 : ", pTag.text());


        // 3. 내가 원하는 요소의 내용 수정해보기
        // v-JS : .innerText = '변경 값'
        // jQuery : .text('변경 값')
        console.log("텍스트만 : ", pTag.text("메에에에엥타몽"));

        // 3-2. 태그까지 포함해서 수정하기
        // v-JS : .innerHTML = '변경 값'
        // jQuery : .html('변경 값')
        pTag.html('<h1>html로 바꾼 값</h1>')


        // 4. 버튼을 클릭했을때 input 태그의 값으로 내용을 변경
        // v-JS : .addEvnentListner('click',() => {} )
        // jQuery : .click( () => {} )
        $('#btn').click( () => {


            // 5. input 태그의 값 가지고 오기
            // v-JS : .value
            // jQuery : .val()
            let val = $('#inputTxt').val();
            console.log('input값 : ',val);

            // 5-2. 내가 가져온 input 값으로 텍스트를 설정
            pTag.text(val);

            // 5-3. input value를 초기화
            $('#inputTxt').val('');
        })


        // 6. 스타일 변경
        // v-JS : .style.속성 = '값';
        // jQuery : .css('속성', "값")
        $('#style-btn').click(() => {
            pTag.css('color',  'hotpink').css('fontFamily', '궁서')
            // 한번에 속성 정의 가능하다 !!
            // ★★★메소드 체인이 가능하다       
        })


        // 7. 속성변경
        // v-JS : .속성, setAttribute
        // jQuery : .attr()
        $('#pic-btn').click(()=>{
            $('#pic').attr('src', 'https://i.namu.wiki/i/5BHb2UsJISdW7UNCo_Q5Dld-BplCMkjfb81-YPIGGQYu5tN0FRzCAPpENK4eqmdPEELS4wGTCLbwnRy5waPNQQ.webp').width('100px');
        })

    </script>
</body>

2.2. 요소 및 태그 접근

  • 다음 카운트 세어주는 기능을 만들어보자
    ( 0보다 작을땐 값이 음수가 되지 않는다 )
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="./js/jquery-3.7.1.min.js"></script>
</head>
<body>
    <span id="num">0</span>
    <br>
    <button id="plus">+1</button>
    <button id="minus">-1</button>

    <script>
        // $ is not defined --> jQuery 로드가 안됬다는 에러!


        // +1 버튼을 누르면 span태그 값을 1씩 증가
        // -1 버튼을 누르면 span태그 값을 1씩 감소
        // span태그 0일때 더 이상 감소하지 않는다 !
        // jQuery 사용해서 해결해보기 !!

        let num = $('#num').text(0);
        let count = 0;

        $('#plus').click(()=>{
            console.log("+버튼 클릭");
            num.text(++count) ;
        })

        $('#minus').click(()=>{
            console.log("-버튼 클릭");
            if (count > 0) {
                num.text(--count) ;
            }
        })


    </script>
</body>

2.3. $(document).on('click', 클릭 될 대상, 함수)

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="./js/jquery-3.7.1.min.js"></script>
</head>
<body>
    <button id="addBtn">버튼 추가하기</button>
    <div id="divTag"></div>
    <script>

        let btn = $('#addBtn');
        let div = $('#divTag');
        // 1. addBtn 버튼을 클릭시
        btn.click(() => {
            // 2. id가 divTag 인 요소안에 '새로운 버튼'
            div.html("<button id='newBtn'>새로운 버튼</button>");
        })


    // ** 새롭게 생긴 버튼에 이벤트를 걸어보자 !
    // 새로운 버튼을 클릭 했을때 -> console 창에 '새로운 버튼 클릭 !'

    // 동적 이벤트 바인딩
        // .click() : 최초로 페이지를 로딩했을때 선언되어 있는 요소에 이벤트 바인딩
        //          그 이후에 동적으로 바인딩하지 않음(확인하지 않음!)

        // .on('click', 클릭 될 대상, 함수) : 동적으로 추가된 요소에 이벤트 바인딩함.
        $(document).on('click', '#newBtn', () => {
            console.log("새로운 버튼 클릭!");
        })


    // 정적 이벤트 임으로, 해당 코드는 작동하지 않음.
        // $('#newBtn').click(()=>{
        //     console.log("새로운 버튼 클릭!");
        // })


    </script>

2.4. 버튼 기능 활용

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="./js/jquery-3.7.1.min.js"></script>

    <style>
        img{
            width: 200px;
            height: 200px;
        }

        .newClass{
            border : 5px solid yellow;
        }
    </style>
</head>
<body>
    <div>
        <img src="./img/bolo.jpg" alt="">
    </div>

    <button id="btn1">div내부 앞에 추가</button>
    <button id="btn2">div내부 뒤에 추가</button>
    <button id="btn3">div외부 앞에 추가</button>
    <button id="btn4">div외부 뒤에 추가</button>
    <br>
    <button id="btn5">img 1개 삭제</button>
    <button id="btn6">div 안 비우기</button>
    <button id="btn7">class 추가</button>
    <button id="btn8">class 삭제</button>
    <button id="btn9">부모요소 접근</button>
    <button id="btn10">this문법</button>

    <script>
        // 1. 요소 내부 앞에 내용 추가 : prepend()
        $('#btn1').click(()=>{
            $('div').prepend('<img src="./img/mali.jpg" alt="">');
        })

        // 2. 요소 내부 뒤에 내용 추가 : append()
        $('#btn2').click(()=>{
            $('div').append('<img src="./img/meta.jpg" alt="">');
        })

        // 3. 요소 외부 앞에 내용 추가 : before()
        $('#btn3').click(()=>{
            $('div').before('<img src="./img/miZz.jpg" alt="">');
        })

        // 4. 요소 외부 뒤에 내용 추가 : after()
        $('#btn4').click(()=>{
            $('div').after('<img src="./img/yote.jpg" alt="">');
        })

        // 5. 요소 지우기 : remove()
        $('#btn5').click(()=>{
            $('#img1').remove();
        })

        // 6. 요소 비우기 : empty()
        // div 내부 전부 비우기
        $('#btn6').click(()=>{
            $('div').empty();
        })

        // 7. class 추가
        $('#btn7').click(()=>{
            $('img').addClass('newClass');
        })

        // 8. class 삭제
        $('#btn8').click(()=>{
            $('img').removeClass('newClass');
        })

        // 9. 부모요소 다루기
        $('#btn9').click(()=>{
            $('img').parent().css('backgroundColor', 'pink');
        })


        // 10. this 문법
        // ** Arrow 와 function 은 함께사용 x
        // this : 자기 참조 함수
        //      이벤트 처리를 해주는 함수 안쪽에서
        //      이벤트가 실행되고 있는 태그 그 자체를 의미 한다.
        $('#btn10').click( function() {
            
            $(this).text('버튼 바꾸기 성공!');
        })


    </script>
</body>

3. 실습 해보기

  • 한상의 대모험 !
  • 배경 이미지에서 벗어나지 않는 선에서 왼, 오른쪽 방향키에 맞춰 움직인다.

  • event

    • 이벤트에 대한 모든 정보가 들어있는 객체
    • 함수의 매개변수를 지정하게 되면 자동으로 event 객체 수집

<head>
    <meta charset="UTF-8" />
    <title>Document</title>
    <link rel="stylesheet" href="css/moveImgStyle.css" />
    <script src="../js/jquery-3.7.1.min.js"></script>

</head>

<body>
    <div id="bg">
        <img id="hansang" src="img/hansang.png" />
    </div>

    <script>
        let key = $('body');
        let img = $('#hansang');

        let point = 0; // 위
        

        // 1. 키보드를 눌렀을 때에 대한 이벤트 처리방법
        key.on("keydown",(event)=>{
            // event : 이벤트에 대한 모든 정보가 들어있는 객체
            // 함수의 매개변수를 지정하게 되면
            // 자동으로 event 객체 수집
            console.log(event)
            console.log(event.keyCode);

            // jQuery 문법 이용해서
            // 방향키 누르면 한상씨가 방향으로 50px 이동 ! 
            // 단, 배경 이미지 밖으로 벗어나지 않도록 할 것 !
         
            if (event.keyCode == '37'){
                    if (point < 1050) {
                        point = (point + 50)
                        img.css('right', point+"px");
                        console.log("왼", point);
            }
                
            } else if (event.keyCode == '39'){
                    if (point > 0) {
                        point = (point - 50)
                        img.css('right', point+"px");
                        console.log("오", point);
            }
                
            } else if(event.keyCode == '38'){
                        console.log("위");
                
            } else if (event.keyCode == '40'){
                        console.log("아");
            } else if (event.keyCode == '32'){
                // 스페이스바를 눌렀을때 점프하도록 !
                $('img').stop(true).animate({"bottom":"300px"}, 500).animate({"bottom" : "150px"},500);
                // .animate({"속성" ㅣ "값"}, 지속시간) : 해당 시간동안 css 변경
                // .stop : 이전 애니메이션을 멈춰주는 작업도 가능

            }
            
            
        })
    </script>
</body>
profile
제가 한 번 해보겠습니다.

0개의 댓글