I recently had a few global variables that I was referencing from a TypeScript file that TypeScript marked with the following error:
Property 'msSpeechRecognition' does not exist on type 'Window & typeof globalThis'.
So I created added the following code into my env.d.ts
(generated and referenced in tsconfig.json
by create-vue
):
declare const msSpeechRecognition: undefined | SpeechRecognitionStatic;
This didn't fix the problem. However, when I switched the code to the following:
declare var msSpeechRecognition: undefined | SpeechRecognitionStatic;
The error on the reference to msSpeechRecognition
disappeared. I understand the differences between const
and var
in JavaScript, but what are the differences when using them in type declarations?
I couldn't reproduce this same issue when replacing SpeechRecognitionStatic
with string
, so I know it's something related to the SpeechRecognitionStatic
type. Here is how it looked like (brought from @types/webspeechapi
):
interface SpeechRecognitionStatic {
prototype: SpeechRecognition;
new (): SpeechRecognition;
}