원래 하루하루마다 작성할 예정이었지만 그렇게 하지 못했다...하핳 2주차 동안 배운 내용을 정리하고, 다음주부터는 하루하루 작성하는 습관을 들이고자 한다..!!

 

일단 2주동안 배운 것은 html, css, DOM 객체, jQuery까지 배웠고, 2주차 마지막 진도를 아직 안나가서 그 부분은 따로 적고자 한다.(Bootstrap을 배운다.) 그리고 위의 내용들도 양이 많다 보니 나누어서 작성할 것이다. 그전에 최근에 배웠던 jquery객체와 부트스트랩에 대한 간단한 회고를 이번 페이지에서 작성하고, html/css/js기초/dom 객체/jquery/부트스트랩으로 나누어 작성할 것이다. 

 

일단 어제 배운 jQuery는 dom 객체 등 자바스크립트 언어를 간편히 사용할 수 있도록 단순화 시킨 js 라이브러리이다.

그 전날에 공부했던 dom 객체와 비교해보며 어떻게 사용하는 지를 배웠다.

1. jQuery CDN 가져오기

먼저 Jquery를 사용하기 위해선 다운로드를 받거나, CDN을 가져와서 사용한다. 여기서 CDN이란, 콘텐츠 전송 네트워크(CDN)이며, 데이터 사용량이 많은 애플리케이션의 웹 페이지 로드 속도를 높이는 상호 연결된 서버 네트워크이다. CDN은 콘텐츠 전송 네트워크 또는 콘텐츠 배포 네트워크를 의미할 수 있으며, 사용자가 웹 사이트를 방문할 때 해당 웹 사이트 서버의 데이터는 사용자의 컴퓨터에 도달하기 위해 인터넷을 통해 이동한다. 즉 다운로드 없이도 CDN을 HTML의 헤드 태그에 붙여준다면 편하게 사용할 수 있다. CDN 사용 과정을 간단히 설명하고자한다.

 

a. 구글에 jQuery를 검색하여 CDN으로 들어간다.

b. jQuery core에서 가장 상위에 있는 uncompressed를 누른다. 

c. Code Integration에서 코드를 복사하고 html의 head 태그에 붙여넣기한다.

위의 과정을 거쳐 html에 코드를 적용한 후에 jQuery를 사용할 수 있다.

 

2. DOM 객체와 비교해보며 jQuery 사용해보기

jQuery를 사용하기 위해선 필연적으로 DOM 객체의 사용법도 알아야한다. DOM에 대한 자세한 설명은 추후의 글에 추가할 것이고, 오늘은 jQuery를 사용하며 알아야하는 사용법 정도만 짚고 넘어가고자 한다. 일단 DOM에서 할 수 있었던

새로운 요소 추가, 삭제, 변경/ 속성 변경/ 스타일 변경/ 이벤트 제어를 jQuery를 통해 모두 할 수 있다. 그리고 HTML에 있는 요소의 값을 가져오는 과정도 DOM 객체보다 편하게 할 수 있다. jQuery의 기본 형태는 다음과 같다.

이런 형태를 기본으로하여 다양한 동작을 실행한다. 중요한 점은 jQuery를 통해서는 새로운 요소를 만들지는 못한다. 그러므로 새로운 요소를 만드는 것은 DOM 객체를 이용한다.

 

일단 값을 가져오는 과정을 선택자를 넣을 때 기존의 CSS 방법과 동일하다. 

태그 태그이름
클래스 .클래스이름
아이디 #아이디이름

속성 선택자나 복합 선택자 등은 CSS를 정리하는 페이지에서 더 자세히 설명할 것이다. 여기서 알아야할 점은

태그 < 클래스 < 아이디 순으로 우선순위가 있다는 것이다. 이는 CSS에서 중요한 점이긴하다.

 

- 값 가져오기

여기서 각 속성에 따라 방법이 살짝씩 다르다. 

input의 값을 가져올때는 val을 사용한다. DOM 객체에서는 아래와 같이 사용했다. 

(let value = document.getElementById("input").value;)

변수 value에 input에 있는 값을 가져와 넣어준다. 이를 jQuery를 사용하여 훨씬 간편하게 가져올 수 있다. 

(let val = $("#input").val();)// 인풋을 아이디로 설정했기 때문에 #으로 지정하여 값을 가져온다.

바로 이렇게 말이다. 훨씬 간단해 진 것을 눈으로 확인할 수 있다.

 

- 값 설정하기

위의 방법을 알았다면 값 변경하는 과정은 정말 쉽다.

DOM 객체 : document.getElmentById("input").value = "안녕";

jQuery : $("#input").val("안녕");

 

- 스타일 변경하기

기본 사용법은 다음과 같다 $(선택자).css("속성","속성값")

DOM 객체 :

let div = document.querySelector("div")

div.style = "border : 1px solid black"

jQuery : $("div").css("border","1px solid black");

 let div = document.querySelector("div");
            div.style = "border: 10px solid black"
 
 $("div").css("border","10px solid black")

DOM으로 사용하면 쿼리셀렉터로 선택하고, 선택한 태그가 들어간 변수에 .style을 이용하여 스타일을 변경했지만, jQuery를 사용하면 위와 같이 짧고 편리하게 적용할 수 있다.

 

- 속성 추가하기

DOM 객체 : 요소.setAttribute("속성명","지정할 속성 값")

jQuery : $(선택자).attr("속성",''속성 값')

 let input = document.querySelector("input");
 input.setAttribute("placehoder","내 이름");

 $("#li").attr("style","color : red");

원하는 속성을 지정하고 그 값을 넣을 수 있다.

 

- Text, HTML 변경하기

DOM 객체 : 

 let div = document.querySelector("div");
            div.innerText = "제이쿼리 사용 전 클자 바꾸기"

jQuery : $(선택자).text("변경할 문자 내용")

$("div").text("<b>제이쿼리 사용 후</b>")

-----------------------------------------------------------------------------------------------------------------------------------------------------------------

DOM 객체 :

 let div = document.querySelector("div");
 div.innerHTML = "제이쿼리 사용 전 클자 바꾸기"

jQuery : $(선택자).html("변경할 내용")

 $("div").html("<b>제이쿼리 사용 후</b>")

둘 다 선택한 요소의 내용을 바꿔준다. 하지만 text와 html의 차이는 text는 문자만 변경하지만 html은 작성한 태그까지 같이 적용해준다는 점이다. 즉 text로 변경한 내용은 <b></b>가 문자 그대로 들어가지만, html 변경할때는 <b></b>가 적용되어 볼드채로 바꾸어준다. 이점을 기억하고 사용하는 것이 좋다.

 

 

- 요소 제어

요소 내의 내용을 변경하는 것이 아니라 추가하고, 요소 자체를 선택한 요소에 추가, 삭제, 탐색하는 방법에 대해 알아볼 것이다. 요소를 추가할 때는 추가하기 전에 요소를 만들어줘야 한다.

 

추가

추가하는 방법에는 여러가지 방법이 존재한다.

.append(요소 or 변경할 내용); //선택한 요소의 자식 요소 중 마지막에 추가 문자열과 노드 객체 모두 삽입 가능하다.

.appendChild(요소); // 선택한 요소의 자식 요소 중 마지막에 노드 객체만 삽입할 수 있다.

.prepend( 요소 or 변경내용); // 선택한 요소의 자식 요소의 맨앞에 문자열과 노드 객체를 삽입할 수 있다.

.before( 요소 ); // 선택한 기준 요소의 앞에 요소를 추가한다.

.after( 요소 ); // 선택한 기준 요소의 뒤에 요소를 추가한다.

 

삭제

.remove(.클래스이름,#아이디 ); //선택한 요소를 DOM 트리에서 삭제한다. 조건을 걸어서 조건에 만족하는 요소만 삭제하는 것도 가능하다.

ex) $("h1").remove(".r1"); // r1을 클래스 값으로 가지는 모든 h1 요소를 삭제한다.

.empty(); // 선택한 요소의 자식 노드를 모두 삭제한다.

 

탐색

.parent().함수(); // 바로 위에 존재하는 하나의 부모 요소를 선택한다.

.parents().함수(); // 선택한 요소의 모든 상위 요소를 선택한다.

.next().함수(); // 선택한 요소의 바로 다음의 형제 요소를 선택한다.

.prev().함수(); // 선택한 요소의 바로 이전의 형제 요소를 선택한다.

.children().함수(); // 선택한 요소의 자식 요소를 모두 선택한다.

 

- 클래스 제어

.addClass(“클래스명”); // 선택한 요소에 클래스를 추가한다.

.removeClass(“클래스명”); // 선택한 요소에 클래스를 제거한다. 클래스를 제거해도 class=""는 남아있다.

.hasClass(“클래스명”); // 선택된 요소에 클래스가 있는지 없는지 판별하고 클래스가 있다면 true를 반환하고 없다면 false를 반환한다.

.toggleClass(“클래스명”); // 선택된 요소에 클래스가 있다면 제거하고 없다면 추가한다.

 

여기서 특별히 switchClass가 있는데 이를 사용할려면 jQuery uidml의 CDN을 가져와 헤드 태그에 넣어주면 사용할 수 있다.

 

$( 선택자 ).switchClass(“클래스명1”, “클래스명2”, 시간);

위에 적은 모든 것들의 . 앞에는 $(선택자)가 들어가지만 생략한 것이다. 어쨌든 이렇게 switchClass는 클래스 1에서 클래스 2로 바꿀때 걸리는 시간을 조정해주면 자연스럽게 클래스가 바뀐다. 보통 css에 클래스를 만들어 스타일을 바꾸는 데 사용한다.

 

- jQuery의 이벤트 리스너

이벤트 리스너란 이벤트가 발생했을 때 그 이벤트에 맞추어 실행할 함수를 지정해주는 것을 말한다.

기본적인 사용법은 다음과 같다.

 $(선택자).on("이벤트명",콜백함수)

그리고 자주 사용하는 이벤트의 경우에는 .on을 사용하지 않아도 바로 사용할 수 있는 이벤트들이 있는데 다음과 같다.

click, scroll, mousehover, hover, keyup, keydown

영어 뜻과 동일하게 각각의 이벤트가 발생했을 때, .on 없이 바로 $(생성자).click(function(){})으로 사용할 수 있다.

 

이들을 이용한 실습은 다음페이지에서 다루도록 할 것이다. 

 

 

 

 

 

 
 

+ Recent posts