javascript

@ts-expect-error иногда не лучше @ts-ignore

  • пятница, 24 мая 2024 г. в 00:00:08
https://habr.com/ru/articles/816285/

Всем уже давно понятно, что вместо директивы @ts-ignore следует использовать директиву @ts-expect-error. Пригождается она даже самым квалифицированным и педантичным разработчикам, например, чтобы временно заглушить ложную ошибку типов из кривого @types/* пакета.

Однако, далеко не все знают, что обе директивы одинаково опасны, если использовать их неосторожно, ведь заглушить ими можно не только ошибки типов, но и откровенно невалидный синтаксис, который гарантированно приведет к выбросу исключения в рантайме.

Убедимся на реальном примере:

declare const obj: {
  prop?: {
    innerProp: string;
  }
}

// @ts-expect-error
obj.prop?.innerProp = 'hello, world'

Спокойно компилируется через TypeScript v5.4.5 со строжайшим конфигом, однако в рантайме нас неминуемо ждет Uncaught SyntaxError: Invalid left-hand side in assignment. И я видел такой код, в проде, причем исключение это проглатывалось, делая эту дичайшую ошибку по сути невидимой, пока не запустишь дебаггер.

На самом деле ухищряться особо не нужно — компилятор считает, что директива уместна даже в случае присвоения значения к примитиву

// @ts-ignore
'LHS' = 'RHS'

Но мы-то теперь знаем, что здесь будет в рантайме — очередное исключение Uncaught SyntaxError: Invalid left-hand side in assignment.

TS1177 не волнует ваш игнор, в бинарных числах троек нет
TS1177 не волнует ваш игнор, в бинарных числах троек нет

Следует отметить, что ошибки вроде TS1177, TS1489 и некоторые другие, оверрайдят обе директивы и не позволяют программисту уйти в полный игнор.

Надеюсь, в будущем это поведение будет как-то унифицировано и все очевидно критические ошибки будут оверрайдить обе директивы, а пока остается только помнить об ответственности, связанной с использованием этих этой директивы.