解决typescript Cannot redeclare block-scoped variable

摘要:没有依赖框架来写typescript,纯粹新建一个ts文件,使用tsc编译成js后,ts文件里的声明的变量、函数名都会报错:其实我们写的ts代码是没有问题的,只是ts会对我们声明的变量、具名函数、class都放在了全局作用域

没有依赖框架来写typescript,纯粹新建一个ts文件,使用tsc编译成js后,ts文件里的声明的变量、函数名都会报错:

Duplicate identifier | Duplicate function // 这是具名函数和class的报错

或者

Cannot redeclare block-scoped variable // 这是声明的变量报错

其实我们写的ts代码是没有问题的,只是ts会对我们声明的变量、具名函数、class都放在了全局作用域,在生成js文件后,js文件里的变量、函数、class会跟ts文件的重复。


解决办法

在ts文件顶端加上:

export {}

再次编译ts文件,可以看到编译后的js文件加上了:

"use strict";
exports.__esModule = true;

它会把整个文件当成一个模块来处理。这样就不会报错了。

本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://shenqiku.cn/article/FLY_8003