1편 - ‘자바스크립트 예외(Exception) 처리하기’

에러(Error) 객체

new Error(message, fileName, lineNumber)

매개 변수


⚠️  fileName과 lineNumber는 모든 브라우저에서 지원하지는 않는다.

👉  fileName과 lineNumber 브라우저 호환성 살펴보기

에러(Error) 객체 생성

new 키워드 없이 Error 함수를 호출했을 때(1번), Error 객체를 리턴해 new 키워드를 사용해 객체를 생성했을 때(2번)와 동일하게 Error 객체를 가진다.

즉, 1번과 2번 결과는 동일한 Error 객체를 가지기 때문에 어느 것을 사용해도 괜찮다. 👌

Error('에러 생성!');    // 1: 함수로 호출 
new Error('에러 생성!') // 2: 객체로 호출

커스텀 에러(Error)

👉  커스텀 에러를 만드는 좋은 방법

ES6 이전

ES6 이전 문법은 기존 Error에 prototype을 수정하거나 확장해 커스텀 에러를 만들 수 있다.

function CustomError(message) {
    this.message = message;
    this.stack = new Error().stack;
}

CustomError.prototype = Object.create(Error.prototype);
CustomError.prototype.name = 'CustomError';

ES6 이후

ES6 문법부터 클래스(Class) 문법을 지원하기 때문에 더 간결해진 코드를 작성할 수 있다. 기존 Error를 상속받아 수정하거나 확장해 커스텀 에러를 만들 수 있다.

class CustomError extends Error {
    constructor(message) {
        super(message);
        this.name = 'CustomError';
    }
    
    toString() {
        return `${this.name}: ${this.message}`;
    }
}

마치며, 🙇🏻

참고한 사이트

https://developer.mozilla.org/ko/docs/Web/JavaScript/Reference/Global_Objects/Error

https://stackoverflow.com/questions/1382107/whats-a-good-way-to-extend-error-in-javascript

https://imkh.dev/js-error