Пользовательский класс ошибок в TypeScript

Я хотел бы создать свой собственный класс ошибок в TypeScript, расширяя core Error для обеспечения лучшей обработки ошибок и настраиваемой отчетности. Например, я хочу создать HttpRequestError класс с url, ответом и телом, переданным в его конструктор, который отвечает с Http-запрос на http://example.com сбой с кодом состояния 500 и сообщением: что-то пошло не так и правильная трассировка стека.

как расширить основной класс ошибок в TypeScript? Я уже нашел сообщение в SO:как расширить объект хоста (например, ошибка) в TypeScript но это решение не работает для меня. Я использую TypeScript 1.5.3

какие идеи?

3 ответов


пока 1.6 не катится, я только что делал свои собственные расширяемые классы.

class BaseError {
    constructor () {
        Error.apply(this, arguments);
    }
}

BaseError.prototype = new Error();

class HttpRequestError extends BaseError {
    constructor (public status: number, public message: string) {
        super();    
    }
}

var error = new HttpRequestError(500, 'Server Error');

console.log(
    error,
    // True
    error instanceof HttpRequestError,
    // True
    error instanceof Error
);

TypeScript 2.1 имел разрушительные изменения в отношении расширения встроенных модулей, таких как ошибка.

С TypeScript breaking changes documentation

class FooError extends Error {
    constructor(m: string) {
        super(m);

        // Set the prototype explicitly.
        Object.setPrototypeOf(this, FooError.prototype);
    }

    sayHello() {
        return "hello " + this.message;
    }
}

затем вы можете использовать:

let error = new FooError("msg");
if(error instanceof FooError){
   console.log(error.sayHello();
}

Я использую TypeScript 1.8 и вот как я использую пользовательские классы ошибок:

UnexpectedInput.ТС

class UnexpectedInput extends Error {

  public static UNSUPPORTED_TYPE: string = "Please provide a 'String', 'Uint8Array' or 'Array'.";

  constructor(public message?: string) {
    super(message);
    this.name = "UnexpectedInput";
    this.stack = (<any> new Error()).stack;
  }

}

export default UnexpectedInput;

MyApp.ТС

import UnexpectedInput from "./UnexpectedInput";

...

throw new UnexpectedInput(UnexpectedInput.UNSUPPORTED_TYPE);

для версий TypeScript старше 1.8 вам необходимо объявить Error:

export declare class Error {
  public message: string;
  public name: string;
  public stack: string;
  constructor(message?: string);
}