[ 모던 자바스크립트 스터디 ] 프로퍼티 어트리뷰트
·
Archive/Develop
내부 슬롯 & 내부 메서드 내부 슬롯과 내부 메서드는 자바스크립트 엔진의 구현 알고리즘을 설명하기 위해 ECMAScript 사양에서 사용하는 의사 프로퍼티와 의사 메서드다. ECMAScript 사양에 등장하는 이중 대괄호로 감싼 이름들이 바로 그것들이다. 내부 슬롯과 내부 메서드는 자바스크립트 엔진에서 실제로 동작은 하나 개발자들이 직접 사용할 수 있도록 공개된 프로퍼티는 아니다. 원칙적으로 내부 슬롯과 내부 메서드에 직접적으로 접근하거나 호출할 수 있는 방법을 제공하지는 않는다. 하지만 일부에 한해 간접적으로 접근할 수 있는 수단을 제공한다. 모든 객체는 [[Prototype]] 이라는 내부 슬롯을 갖고, 이는 __proto__ 를 통해 간접적으로 접근할 수 있다. 사실 이 언더스코더 2개를 통해 호출..
[ PostgreSQL ] CASE WHEN ~ END 와 비교연산(<>)
·
Archive/Develop
PostgreSQL 에서의 조건문이다. 계속 쿼리 보면서 느낌적인 느낌으로 해석하다가 한번 정리해두면 좋을 것 같아서 기록해둔다. CASE WEHN ~ END CASE WHEN 조건 THEN 결과 WHEN 조건2 THEN 결과2 [ELSE] 결과2 END [AS alias] 굉장히 심플하다. 다음은 내가 좀 생소했던 연산자인 이다. 비교연산 != 과 같은 연산자이다. 왼쪽과 오른쪽은 동일하지 않다는 의미이다.
구조적 서브타이핑 / 잉여 속성 체크
·
Archive/Develop
아침에 유튜브 보면서 출근준비하다가 내가 의아해했던 부분을 설명해주셔서 안잊으려고 급하게 포스팅한다. 대체 무슨 기준으로 구조적 서브타이핑이 적용되고, 잉여 속성 체크가 적용되는 것일까? 여기서 구조적 서브타이핑은 상위와 하위의 개념으로, 상위의 개념이 하위를 포함하고 있는것이다. 구조적 서브타이핑에서는 하위가 다른 어떤 프로퍼티를 가지고 있는지 관심이 없다. 그저 상위의 프로퍼티만 가지고 있으면 된다. 하지만 잉여 속성 체크는 그에 반해 상위에 없는 프로퍼티를 가지면 에러를 발생시킨다. 이 둘의 발동 조건은 바로 객체 리터럴을 사용하냐, 사용하지 않느냐에 따라 나뉜다. interface box { color: string; } // 잉여 속성 체크 box({ color: "red", other: tru..
[ 모던 자바스크립트 스터디 ] let, const 키워드와 블록 레벨 스코프
·
Archive/Develop
30초 정리 - var vs let vs const 변수 선언 -> const 재할당 필요한 변수 선언 -> let 변수 선언 시 기본으로는 const 로 선언하고, 재할당이 필요하다면 그때 가서 let 으로 바꾸세요! ES5까지 변수를 선언할 수 있는 유일한 방법은 var 였지만, ES6 부터는 let, const 키워드로도 변수 선언이 가능해졌다. 우선 기존의 var 키워드가 어떤 문제가 있었는지 살펴보자. 변수 중복 선언 허용 var x = 1; var y = 1; var x = 100; var y; console.log(x); // 100 console.log(y); // 1 var 키워드로 선언한 x 변수와 y 변수는 중복 선언 되었으나 에러가 발생하지 않는다. 만약 내가 위에 apple 이라는..