Node.js 의 잠재적 위험성
프론트엔드의 에러는 뷰의 일관성을 해칠 수는 있으나 전반적인 동작에 영향을 크게 미치지는 않는다. 그러나 예외처리가 제대로 되지않은 백엔드의 단순한 에러 하나로 서버가 다운될 수 있다.
이는 자바스크립트에 기인한 잠재적 위험성이다.
JavaScript 의 약점
동적 타입 언어는 버그가 나올 확률이 굉장히 높아진다.
1. 실행시간에 정해지는 변수타입
이에따른 개발자의 실수로 인한 오류가 발생하기 쉽고 찾기도 까다로움. 변수에 잘못된 타입의 값이 할당되어 발생한 오류를 찾기 위해서는 실행시간에 변수의 값과 타입을 모두 확인해야 함.
2. 약한 타입 체크
JavaScript 는 let, const 와 같이 변수/ 상수를 구분하는 정도의 키워드만 지원 된다.
다음과 같은 코드가 가능하고 이로 인해 예기치 않은 문제가 생길 수 있다.
let a = 1;
a = “Hello”;
3. 물렁물렁한 객체
다음과 같이 longitude 를 longitute 로 작성하면 longitute 가 undefined 가 되기 때문에 result 가 NaN (Not a Number) 이 된다.
const obj = { latitude: 11.5, longitude: 47.1 };
const result = obj.latitude * obj.longitute; // 보통은 이런 실수는 컴파일러가 잡아줘야 되는데
console.log(result) // NaN이라는 엉뚱한 값 출현!
'TypeScript' 카테고리의 다른 글
[TypeScript] .d.ts 파일 (0) | 2023.07.25 |
---|---|
[TypeScript] tsconfig.json 옵션 (0) | 2023.07.25 |
[TypeScript] 컴파일러와 tsc (타입스크립트 컴파일러) (0) | 2023.07.25 |
[TypeScript] 맥 TypeScript 개발환경 구축 (0) | 2023.07.25 |
[TypeScript] 타입스크립트 (0) | 2023.07.25 |