Using TypeScript
AirCode supports TypeScript. You can directly use TypeScript in the AirCode environment.
TypeScript provides convenience in the following scenarios:
- Static type checking, which helps improve the robustness and maintainability of your code.
- Support for the latest ECMAScript features while also being compatible with JavaScript.
- Provides object-oriented programming capabilities such as classes, interfaces, and modules.
- And more...
Create a New TypeScript Application
When creating a new application, you can choose to use TypeScript as the default language. Here's how:
- Click to create a new application.
- In the pop-up window, check the box for TypeScript:
data:image/s3,"s3://crabby-images/e5835/e58353c69a85ad430cc990881fea5bce7246ee4c" alt=""
- Click confirm, and the default function code for your new application will use TypeScript:
data:image/s3,"s3://crabby-images/a4288/a4288b5423967bce529976a2df29418260f63f79" alt=""
Enable TypeScript for Existing JavaScript Applications
If you have an existing JavaScript application, you can also enable TypeScript. Follow these steps:
- Install the TypeScript dependency:
data:image/s3,"s3://crabby-images/685e8/685e8d7dfbcfd6767062bb47903c8d2b0d275c26" alt=""
- Create a
tsconfig.json
file (the system will automatically fill in the best practices for configuration, generally no secondary modifications are needed):
data:image/s3,"s3://crabby-images/c0ebf/c0ebf7a011cecc0ceefb35caae7b657377fd4854" alt=""
- Create your TypeScript function, then debug or deploy. In the console, you can see the logs indicating whether the TypeScript compilation was successful or failed:
data:image/s3,"s3://crabby-images/08b91/08b91bb9c4f0bc4d8c3eac9510d13903c88f757e" alt=""
Importing ES Module Modules in TypeScript
AirCode supports importing ECMAScript Modules(ESM) in TypeScript. To import ESM, you need to modify your tsconfig.json
configuration by changing moduleResolution
to "NodeNext"
. Then, change the file extension of your cloud function file from .ts
to .mts
.
json
{
...
"compilerOptions": {
...
"moduleResolution": "NodeNext"
}
}
{
...
"compilerOptions": {
...
"moduleResolution": "NodeNext"
}
}