본문 바로가기

JavaScript30

IM15일차 초보개발자 TIL(fetch) 클라이언트에 관련된 과제를 진행하였다. fetch를 이용하여 data를 받아와 client에 구현될 수 있도록 하는 작업이었다. fetch API 는 리소스 취득을 위한 인터페이스이다. ES6의 사용이 많아짐에 따라 fetch API의 사용도 증가하는 추세이다. fetch(URL) .then(res => res.json()) .catch(err => console.log(err)) fetch함수를 이용하여 URL을 받아고 .then을 이용해 callback함수를 실행한다. .catch를 사용하여 에러가 발생하였을때 핸들링 해주면 된다. 다만 fetch함수 만으로 data를 바로 사용할 수 없다. res에는 body가 담겨져 나오는데 이거 자체는 스트림이고 완전히 data를 가져오는 것이 아니다. 그렇기 .. 2020. 5. 20.
[Javascript]Object.create() & ES6 프로토타입을 상속받는 방법에는 추가적인 방법이 더 있다. 그중 하나는 Object.create() 를 사용하는 방법과 ES6 두가지가 존재한다. Object.create() 사용 Object.create() 는 포로토타입의 객체 및 속성을 그대로 가져오는 메소드로, 상위클래스의 메소드를 하위클래스 메소드로 가져올 수 있다. 다만 상위클래스의 constuctor가 복사되어 오기 때문에 하위클래스 constuctor를 따로 지정해 주어야 한다. 이전 포스팅에서 사용했던 예제를 이용해 보겠다. function Player(name, team, position){ this.name = name this.team = team this.position = position } player.prototype.homer.. 2020. 5. 12.
Object Prototypes prototype 프로토타입은 흔히 '시제품'이나 '견본'의 의미를 뜻하며, 자바스크립트 내에서는 객체의 속성이 아닌 객체의 프로토타입 속성으로 정의된다. 즉, 객체의 원형으로 하나의 틀이라고 생각하면 된다. 자바스크립트는 흔히 프로토타입 기반의 언어라고 부르며, 모든 객체와 속성을 받는 템플릿으로 프로토타입 객체를 가진다고 할 수 있다. 상위 프로토타입 객체로 상속받기 위해 연결하는 것은 프로토타입 체인이라고 부른다, 프로토타입 속성에서 파생된 객체를 __proto__ 로 접근이 가능 하다. prototype 예제 프로토타입을 이해하기 위해서 우선 프로토타입의 예제를 통해서 알아보자. function player(name, team, position){ this.name = name this.team .. 2020. 5. 10.
[Javascript] Scope Scope란 지역적인 뜻을 내포하고 있으며, 쉽게말해 어떤 블록({})이나 함수를 만들었을 때 그 범위에 해당되는 것을 의미하기도 한다. 우리가 변수를 선언할때 흔히 var / let / const 이 3가지를 쓰고 있으며, 이 3개는 각각 다른 특징을 가진다. 우선 첫번째로 var 에 대해서 설명하고자 한다. var는 해당 함수 레벨 scope에서 변수로서 정의되어 작동한다. 예를 들어 var abs = 10 function numb () { var abs = 20 console.log(abs) } console.log(abs) // 10 numb() // 20 함수내에서 정의된 값은 함수가 생성되면 그 값을 받고, 함수 밖에서 경우에는 함수 밖(전역)에서 정의한 값을 받는다. 하지만 블록 레벨 sco.. 2020. 5. 1.
git workflow & conflict 해결 이전에 git 과 github 사용 법에 대해 배워왔다. 이번에는 pair programming을 위한 workflow를 배워보도록 하자. 그전에 우선 git workflow가 어떻게 이루어지는 지를 알아야 한다. git workflow github에서 fork를 하고 my repo에서 git clone을 하게 되면 local로 작업을 불러들일 수 있다. working directory에서 코딩작읍을 한 이후 git add를 통해 staging area에 저장되고 git commit을 하여 해당 작업에 대한 메세지를 넣어 local repo로 옮겨진다. 이상태에서 git push origin master를 입력하여 my repo로 넘어간다. 새로운 브랜치를 만들어 진행하기 위해서는 git checkout.. 2020. 4. 29.
DOM DOM 이란 HTML 또는 XML document와 상호작용하고 표현하는 API이다 페이지의 구조, 컨텐츠 및 스타일을 구현할 수 있는 인터페이스이다. 다음은 자바스크립트에 의해 구현되는 DOM의 예시이다. let newdiv = document.querySelector('.id') let divElement = document.createElement('div') divElement.classList.add('newid'); divElement.textContent = document.getElementById('namebox').value; newdiv.appendChild(divElement); DOM의 요소를 선택하는 방법에 대해 하나하나씩 찾아보기로 하자. querySelector를 사용한 요소.. 2020. 4. 24.
5주차 초보개발자 TIL 4주간의 PRE course가 끝나고 개인 학습 시간을 가지는 한주 였다. 화요일 이때까지 배워왔던 중요한 부분에 대한 test를 진행하였다. 코플릿 문제를 비롯하여 알고리즘, array 메소드, DOM , 재귀 함수를 이용한 문제들이었다. 가장 어려웠던 문제는 array 메소드였다. 아직까지 map메소드와 reduce메소드에 대한 이해가 많이 부족하구나 하는 걸 느꼈다. 시험이 끝난 이후 다시 한번 map과 reduce 메소드에 대한 내용을 다시 한번 되짚어 보고, 더 부족한 점이 없는지 확인 하는 시간이 되었다. 5주차 한주동안 부족한 부분이 무엇인지 더 찾아보고 다음주 진행 되는 Immersive course에서 뒤 떨어지지 않도록 준비를 해야 겠다는 생각이 드는 주차였다. 2020. 4. 23.
HTML / CSS HTML 하이퍼텍스트 마크업 언어 뜻하며 요소와 속성으로 이루어 져 있으며 꺽쇠 로 표현된다. 웹 브라우저를 표현하는 데 사용되며, 자바스크립트와 CSS 를 연동하여 사용한다. 즉 웹브라우저의 기본적인 뼈대라고 생각하면 된다. 마크업의 기본 구조는 다음과 같다. Hello World! 마크업 요소는 다음과 같다. 단락바꾸기 단락바꾸기 목록 순서없는 목록 만들기 줄바꾸기 테이블표 만들기 버튼만들기 그리고 마크업 속성으로 표현 하기 위해 = 을 붙이며 이 속성에는 id 와 class가 있다. id는 고유식별자로 하나만 존재하며, 스타일 시트를 통해 꾸밀 수 있다. class는 유사한 요소를 구현하기 위해 사용되며, 해당 class값을 갖는 모든 요소들을 해당 텍스트에 종속된다. HTML CSS 캐스케이팅 스.. 2020. 4. 23.
[Javascript] 재귀함수 (알고리즘) 알고리즘이란 어떠한 문제를 해결하기 위해 정해진 일련의 절차나 방법을 공식화한 형태로 표현한 것, 계산을 실행하기 위한 단계적 절차를 의미한다. 알고리즘에 대한 공식적인 정의는 없지만, 좋은 알고리즘의 조건은 존재한다. 정밀성 : 변하지 않는 명확한 작업 단계를 가져야 한다. 유일성 : 각 단계마다 명확한 다음 단계를 가져야 한다. 타당성 : 구현할 수 있고 실용적이어야 한다. 입력 : 정의된 입력을 받아들일 수 있어야 한다. 출력 : 답으로 출력을 내보낼 수 있어야 한다. 유한성 : 특정 수의 작업 이후에 정지해야 한다. 일반성 : 정의된 입력들에 일반적으로 적용할 수 있어야 한다. 그리고 알고리즘을 구현하는 방식으로 재귀 알고리즘이 있으며, 이것이 재귀함수이다. 재귀함수란 하나의 함수에서 자신을 다시.. 2020. 4. 23.