如何在Javascript中使用已编译的TypeScript类

前端之家收集整理的这篇文章主要介绍了如何在Javascript中使用已编译的TypeScript类前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
@H_301_1@想象一下,我有这个简单的TypeScript类,Animal.ts:

@H_301_1@

export default class Animal {
  constructor(public name : string) { }
}
@H_301_1@使用此tsconfig.json文件

@H_301_1@

{
  "compilerOptions": {
    "target": "es5","module": "commonjs","strict": true
  },"files": [
    "Animal"
  ]
}
@H_301_1@如何在javascript文件中使用此类的编译版本(通过运行tsc编译),如下所示:

@H_301_1@

var Animal = require("./Animal");

var newAnimal = new Animal();
@H_301_1@我应该在tsconfig.json文件中编辑一些东西吗?我得到的错误是:

@H_301_1@

@H_301_1@ReferenceError: Animal is not defined

最佳答案
正如Shane van den Bogaard所指出的,需要省略Animal.ts中的默认关键字,并且:

@H_301_1@

const { Animal } = require('./Animal');
@H_301_1@应该用来代替

@H_301_1@

var Animal = require('./Animal');
@H_301_1@这样我们可以通过使用调用Animal类并初始化一个对象

@H_301_1@

const { Animal } = require('./Animal');
var newAnimal = new Animal("Clifford");

猜你在找的JavaScript相关文章