혼공학습단9기_자바스크립트

혼공단 자바스크립트 5주차 일지

퓨어워터맨 2023. 2. 11. 22:19
728x90
반응형

안녕하세요 모두 새해 복많이 받으세요

벌써 5주차 입니다. 시간은 정말 빠르네요. 특히 연초는 더더욱 그런것 같습니다. 

혼공 학습이 2주밖에 남지 않았네요. 더더욱 집중해서 유종의 미를 거둘 수 있도록 최선을 다하겠습니다. 

구분 진도 기본 미션 선택 미션
1주차
(1/2 ~ 1/8)
Chapter 01 ~ 02 p.54의 <파일 만들고 저장해 실행하기>에서  "Hello World" 출력하기 Ch.01(01-1)확인 문제 1번 상세하게 적고 인증하기
2주차
(1/9 ~ 1/15)
Chapter 03 p. 139의 확인 문제 3번 문제 풀고 완전한 코드 만들어 비쥬얼 스튜디오 코드에서 실행 결과 인증하기 p. 139의 확인 문제 3번 문제 풀고 완전한 코드 만들어 비쥬얼 스튜디오 코드에서 실행 결과 인증하기
3주차
(1/16 ~ 1/22)
Chapter 04 p. 195의 확인 문제 4번 풀고 인증하기 p. 183 [좀 더 알아보기] 손코딩 실행하고 결과화면 인증하기
🙇설 연휴🙇
(1/23 ~ 1/29)
야호! 한 주 쉬어갑니다 ❣️새해 복 많이 받으세요❣️ 야호! 한 주 쉬어갑니다
4주차
(1/30 ~ 2/5)
Chapter 05 p.202 <윤년을 확인하는 함수 만들기> 예제를 실행하여 2022년이 윤년인지 확인하는 결과 인증하기 p. 240 확인문제 1번 풀고, 풀이 과정 설명하기
5주차
(2/6 ~ 2/12)
Chapter 06 객체, 속성, 메소드가 무엇인지 설명하기 p.288 확인 문제 3번 풀고, 풀이 과정 설명하기
6주차
(2/13 ~ 2/19)
Chapter 07 ~ 08 p. 315의 <직접 해보는 손코딩>을 실행한 후 출력되는 고양이 이미지 캡쳐하기 p. 352 누적 예제를 활용하여 본인의 할 일 목록을 만들어 캡쳐하기

 

기본미션 :객체, 속성, 메소드가 무엇인지 설명하기
객체(Object) 실제로 존재하는 사물. name과 value로 구성된 속성을 가진 기본 데이터 타입
속성(Property) name과 value로 표현되는 속성
메소드(Method) 속성ㅈ 중에서 동작(함수) 인 것.

* 객체와 배열에 대한 보충 설명

배열(Array)도 지정위치(index)에 값(value)를 넣는다는 형식으로 본다면 객체와 유사하다고 볼 수 있습니다. 

하지만 배열은 순서대로 차곡차곡 지정된 위치에 데이터를 넣는 반면

객체의 경우에는 내가 위치를 지정하고, name을 만들어서 넣을 수 있습니다. 

이를 key 값에 대응시킨다고 이야기를 합니다. 

 

객체를 생성하여 원하는 데이터를 넣고, 사용할 수 있는 것이 자바스크립트의 가장 큰 장점입니다. 

 

1> 객체 

데이터 타입 중 하나로, 다양한 데이터를 저장하고 처리하는데 사용

 

객체를 생성하는 방법에는 두가지가 있음

(1) 객체 생성자 문법 : Object() 생성자를 사용하여 객체를 생성하는 방법

let o = new Object();

(2) 객체 리터럴 문법 : 중괄호{}안에 키(key) : 값(value) 쌍으로 구성된 속성을 여러개 넣어 객체를 생성하는 방법

키에는 문자형만 가능, 값에는 모든 자료형이 올 수 있음

let o = {
  name : "Kim",
  age : 38
};

2> 속성

객체 내부에 있는 값으로, 점 표기법을 이용하여 접근 가능

console.log(o.name); // Hongong
console.log(o.age); // 18

자바스크립트는 객체에 속성을 동적으로 추가 할 수 있음

delete o.age;
console.log(o.age); // undefined​

delete 연산자를 사용하여 삭제가 가능

o.address = "Seoul"

스페이스나 "-"이 들어가는 속성이름은 따옴표로 감싸야 한다.

let o = {
  "s p a c e" : true 
}

3> 메소드

객체의 속성 중에서도 함수를 메소드라 지칭

let user = {
  // 속성
  name : "John",
  age : 18
  // 메소드
  eat : function(){
    console.log("밥을 먹습니다.");
  }
};

자바스크립트는 함수와 메소드가 분리된 개념이 아니기 때문에 기존에 정의된 함수를 메소드로 등록 가능

let user = {
  name : "John",
  age : 18,
};

function eat(){
  console.log("밥을 먹습니다.");
};

user.eat = eat;

메소드에서 this 키워드를 사용하면 자기자신이 가지고 있는 속성임을 의미

let user = {
  // 속성
  name : "John",
  age : 18
  // 메소드
  eat : function(){
    // this는 현재 객체를 나타냄 -> user.name
    console.log(`${this.name}이 밥을 먹습니다.`);
  }
};
선택미션 : p. 288 확인문제 3번 풀고, 풀이 과정 설명하기
Math 객체를 활용하여 sine 90도 값을 구하기
<script>
  // 변수를 선언합니다.
	const degree = 90  
  
  // 출력합니다.
  	console.log(Math.sin(degree)) // 0.8939966636005579
</script>

사인 90의 경우 1이 나와야 하는데 결과값은 0.89 이상한 값이 나왔습니다.

Math.sin() 함수의 인자는 라디안 값이 들어가야 정확한 결과가 나옵니다.

일반각*Math.PI/180을 함수의 인자로 넣어야 합니다. 

<script>
  // 변수를 선언합니다.
	const degree = 90  
  
  // 출력합니다.
  	console.log(Math.sin(degree * Math.PI / 180)) // 1
</script>

원하는 결과값이 나왔습니다. 

 

 

728x90
반응형