angulartypescriptangular12

How to use Global extension in Angular?


On an Angular 12 application I created the following extension:

declare global {
  interface String {
    toNumber(): number | null;
  }
}

Object.defineProperty(String.prototype, "toNumber", {
  value: function(this: string) {
    return Number(this) || null;
  }
});

When using in an Angular's component:

var number = stringValue.toNumber();

I get the error:

Property 'toNumber' does not exist on type 'string'.

What is the best way to use such extensions in Angular?

Do I need to change the way I am creating the extension?


Solution

  • You can achieve this with the following:

    declare global {
      interface String {
        toNumber(): number | null;
      }
    }
    export {}; // to define this file as a module
    
    Object.defineProperty(String.prototype, "toNumber", {
      value(this: string) {
        return Number(this) || null;
      }
    });
    export {}; // to define this file as a module
    
     import 'PATH_TO_YOUR_FILE/string-extension'