一、Mac上安装typescript
sudo npm install -g typescript
测试一下:出现Version则证明安装成功
tsc -v
二、在VSCode上运行
新建一个xxx.ts文件,测试能否运行
TypeScript
console.log("helloworld")
运行报错:ts-node: command not found
data:image/s3,"s3://crabby-images/ec94b/ec94b93b6f356c3f36ff1446c65de4d969b29ddf" alt=""
再安装ts-node
TypeScript
sudo npm install -g ts-node
运行报错:TypeError [ERR_UNKNOWN_FILE_EXTENSION]: Unknown file extension ".ts"
data:image/s3,"s3://crabby-images/4e683/4e683dc911825d7f4dd9178df7d6f9b08438191a" alt=""
在终端上输入
TypeScript
tsc --init
显示创建了一个tsconfig.json文件
data:image/s3,"s3://crabby-images/c5513/c5513d3792de2b8d6010cf8bfe6130f1de96335e" alt=""
修改文件
TypeScript
vi tsconfig.json
加上"ts-node": {"esm": true}, 注意不要加到"compilerOptions"里去了
TypeScript
{
"ts-node": {"esm": true},
"compilerOptions": {...}
}
再去VSCode里运行,发现成功输出helloworld
三、遇到export问题
TypeScript
export enum abc {
a = 'aa',
b = 'bb'
}
console.log(abc)
运行报错:ReferenceError: exports is not defined in ES module scope
data:image/s3,"s3://crabby-images/18c25/18c259a8e61fd6fcd2a6dcced4ba5a30be860d9f" alt=""
解决方案:在package.json里删除 "type": "module",
TypeScript
vi package.json
删掉 "type": "module",
data:image/s3,"s3://crabby-images/e3a2e/e3a2e176315319e74a3e13f28639ffe211143fb7" alt=""
运行成功