Typescript: пытаюсь расширить класс String … не могу получить ссылку на строковое значение в моем методе

#typescript #binding #extends

#машинописный текст #обязательный #расширяет #typescript #привязка

Вопрос:

 class MString extends String {
    
    constructor(value: string) {
        super(value)
        console.log(typeof this)//string 
    }

    /**
     * replaces substrings in string, based on the keys and values of the 'translation' object passed in.
     * @param str
     * @param translations
     */
    replaceAll(translations: { [key: string]: string }) {
        console.log(this)//MString {}
        let replacedStr: String = this;
        for (const key of Object.keys(translations)) {
            while (replacedStr.includes(key)) {
                replacedStr = replacedStr.replace(key, translations[key]);
            }
        }
        return replacedStr;
    }
}
  

В конструкторе он регистрирует тип ‘this’ как string . Но в replaceAll() он регистрируется как MString {}.

Я также получаю сообщение об ошибке следующим образом:

             while (replacedStr.includes(key)) {
                               ^
TypeError: String.prototype.toString requires that 'this' be a String
    at MString.toString (<anonymous>)
    at MString.includes (<anonymous>)
    at MString.replaceAll (/mnt/d/Dev/bullshit/src/index.ts:24:32)
    at Object.<anonymous> (/mnt/d/Dev/bullshit/src/index.ts:34:17)
    at Module._compile (internal/modules/cjs/loader.js:1138:30)
    at Module.m._compile (/mnt/d/Dev/bullshit/node_modules/ts-node/src/index.ts:1043:23)
    at Module._extensions..js (internal/modules/cjs/loader.js:1158:10)
    at Object.require.extensions.<computed> [as .ts] (/mnt/d/Dev/bullshit/node_modules/ts-node/src/index.ts:1046:12)
    at Module.load (internal/modules/cjs/loader.js:986:32)
    at Function.Module._load (internal/modules/cjs/loader.js:879:14)
  

Та же реализация работает и в javascript.
Я попробовал преобразовать это в строку. Безрезультатно.
Я попытался вызвать super.valueOf(). Безрезультатно.
Я попытался привязать это к методу replaceAll(). Безрезультатно.
Я попытался создать свойство для хранения строки, в которой объект был инициализирован. Но, по-видимому, мне не разрешили это сделать.

Почему я, кажется, теряю ссылку на экземпляр string, как только я использую метод replaceAll()? Есть ли способ для меня получить доступ к значению экземпляра string?

[РЕШЕНО] Благодаря определенной производительности. Я понял, что проблема заключалась в том, что я компилировал в es5 javascript. Вместо этого я должен был скомпилироваться в es6.

Комментарии:

1. Я не могу воспроизвести ошибку на игровой площадке TS (4.0.2), и скомпилированный код, похоже, выполняется так, как требуется

2. Большое вам спасибо. После того, как повозился в моей среде и на игровой площадке. Я узнал, что это было потому, что целью в моем tsconfig был es5. Итак, проблема была не в typescript (его никогда не бывает), а в es5 js.