如果我扩展一个本地导出的类,它就可以工作。
工作示例:
export class classA {
constructor() {
super();
}
}
export class classB extends classA {
constructor() {
super();
this.do();
}
private do(): void {
// do something
}
但是当我从文件外部导入 classA 时,它不起作用。
不工作的例子:
import { classA } from '../'; // I use index.ts file, so the reference is good.
export class classB extends classA {
constructor() {
super();
this.do();
}
private do(): void {
// do something
}
}
文件结构:
Root/
- index.ts
- classA(folder)/
- index.ts
- classA.ts
- classB(folder)/
- index.ts
- classB.ts
classA文件夹下的index.ts文件:
export * from './classA';
根index.ts文件:
export * from './classB';
export * from './classA';
错误信息: 类 classB 扩展 _1.classA 类型错误:类扩展值未定义不是构造函数或 null
我需要从这个文件外部加载,因为我想在其他文件中使用 classA...知道为什么会这样吗?
[已解决]: 在根 index.ts 文件中,顺序必须是:
export * from './classA';
export * from './classB';
最佳答案
直接导入classA。试试这个:
import { classA } from '../classA/classA';
export class classB extends classA {
constructor() {
super();
this.do();
}
private do(): void {
// do something
}
关于javascript - typescript 用导入的类扩展类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44008340/