// 由于此时默认为全局变量
// 因此会报错:无法重新声明块范围变量“name”。ts(2451)
let name = '张三';
// 此时a,b和默认导出的name可以在其他文件导入使用
// c由于未导出,因此在其他文件导入c时会报错
export const a = 1;
export const b = 2;
const c = 3;
export default { name: 'Tom' }
// 导入
// import { a, b } from './xxx.ts'
// 注意:此处可以在当前文件直接使用,也可以在其他文件导入使用
export namespace person {
class Woman { };
// 此处加了export关键字才会被导出,否则则为私有
export class Man {
eat() { return '吃饭' }
}
}
export namespace animal {
class Bird { };
// 此处加了export关键字才会被导出,否则则为私有
export class Tiger {
eat() { return '吃肉' }
}
// 命名空间嵌套命名空间
export namespace monkeyArea {
export class Monkey {
eat() { return '吃水果' }
}
}
}
let p = new person.Man();
console.log(p.eat()); // 吃饭
let t = new animal.Tiger();
console.log(t.eat()); // 吃肉
let m = new animal.monkeyArea.Monkey();
console.log(m.eat()); // 吃水果
补充:同一模块下命名空间一致会合并;不同模块下同名命名空间不会合并
本文主要记录了ts中的模块与命名空间,以供参考。下次再见