在 TypeScript 中,命名空间(Namespace)是一种组织和封装代码的方式,用于解决全局命名冲突的问题。命名空间可以包含变量、函数、类等,并且它们不会污染全局命名空间。

下面是一个简单的 TypeScript 命名空间的示例:
// 定义一个命名空间
namespace MyNamespace {
    export interface Person {
        name: string;
        age: number;
    }

    export function greet(person: Person): void {
        console.log(`Hello, ${person.name}! You are ${person.age} years old.`);
    }
}

// 使用命名空间中的接口和函数
const person: MyNamespace.Person = { name: "Alice", age: 30 };
MyNamespace.greet(person);

在上面的例子中,我们创建了一个名为 MyNamespace 的命名空间,其中包含了一个接口 Person 和一个函数 greet。使用 export 关键字使得这些成员能够在命名空间外部访问。

要在另一个文件中使用这个命名空间,可以使用 reference 指令或者使用模块系统的 import 语句。下面是一个例子:
// 引用命名空间
/// <reference path="path/to/namespaceExample.ts" />

// 使用命名空间中的接口和函数
const anotherPerson: MyNamespace.Person = { name: "Bob", age: 25 };
MyNamespace.greet(anotherPerson);

需要注意的是,命名空间主要在较早版本的 TypeScript 中使用,而在现代的 TypeScript 中,更推荐使用模块(Module)系统来组织和管理代码,因为模块提供了更好的可维护性和可重用性。


转载请注明出处:http://www.pingtaimeng.com/article/detail/13025/TypeScript