3+1 Ways to Declare Global Variables in TypeScript
To declare global variables in TypeScript, create a type definition file ending with .d.ts
, and use the declare var
syntax to declare global variables.
declare var app: {
create(): void
}
// Now you can use without type errors:
app.create()
As long as you create .d.ts
files within your TypeScript project, TypeScript will automatically pick it up to use it as a type definition file.
Using "declare global"
If you would like to define all global variables within a single object, you can use the declare global
syntax, where you need to define all global variables within a global type.
declare global {
var app: {
create(): void
}
}
// Access global variables both with and without referencing the window
app.create()
window.app.create()
If you run into the following error: "Augmentations for the global scope can only be directly nested in external modules or ambient module declarations.", you will be able to resolve it by adding export {}
to the module.
export {}
declare global {
var app: {
create(): void
}
}
Extending the Window Interface
Another way to declare global variables in TypeScript is to extend the built-in Window
interface. Instead of using the declare
keyword, we need to define an interface called Window
, and add our global types on top of it.
interface Window {
app: {
create(): void
}
}
// βοΈ Access through the window object
window.app.create()
// β Cannot find name 'app'.
app.create()
TypeScript will automatically merge this interface with the built-in Window
interface so you will have both the existing and new types. However, this way you will only be able to access global variables through referencing window
. If you try to simply write app.create
, you may run into errors.
data:image/s3,"s3://crabby-images/4aa30/4aa306b3e0a660dbe09aee268c00ec312aa42a70" alt="Master TypeScript"
+1: Using Type Assertion
Lastly, as a quick and easy solution, you can also use type assertion to use global variables in a type-safe way. However, be warned that this is not the recommended way to use global variables in TypeScript, you should only use it as a last resort or in exceptional cases.
// Prevent TypeScript to throw errors for global types
(window as any).app.create()
The downside of using type assertion is that you need to use it each time you are referencing a global variable. For a generic approach, you can use the any
type, however, this will prevent proper type checking for your global variables. Both app
and its create
method are now typed as any
.
data:image/s3,"s3://crabby-images/fd043/fd0435920f32fd4c2a4898f750b95761e30f839b" alt="Mentoring"
Rocket Launch Your Career
Speed up your learning progress with our mentorship program. Join as a mentee to unlock the full potential of Webtips and get a personalized learning experience by experts to master the following frontend technologies:
Courses
data:image/s3,"s3://crabby-images/52081/520818edd603c46644ad755060f45f4a09e9d521" alt="Understanding TypeScript"
Understanding TypeScript
data:image/s3,"s3://crabby-images/3ec30/3ec3008853895f5a14fa186698aae69c91447493" alt="Mastering TypeScript"
Mastering TypeScript
data:image/s3,"s3://crabby-images/664d0/664d0ee78277c4d5b6656f3068bb40bc73a7ff24" alt="TypeScript for Professionals"