typescript的declare module和namespace
时间: 2024-05-02 13:17:27 浏览: 280
`declare module` 和 `namespace` 都是 TypeScript 中用来组织代码结构的关键字,但它们的使用场景和作用略有不同。
`declare module` 用于声明一个模块或库的类型定义,例如:
```typescript
declare module 'my-library' {
export function myFunction(): void;
export const myVariable: string;
}
```
这段代码声明了一个名为 `my-library` 的模块,并且声明了该模块中导出的函数和变量的类型。在实际使用中,如果我们要使用这个模块,可以通过 `import` 来引入:
```typescript
import { myFunction, myVariable } from 'my-library';
```
`namespace` 用于声明一个命名空间,可以将相关的代码组织在一起。例如:
```typescript
namespace MyNamespace {
export function myFunction(): void {
// ...
}
export const myVariable: string = 'Hello';
}
```
这段代码声明了一个名为 `MyNamespace` 的命名空间,并且在其中声明了一个函数和一个变量。在实际使用中,我们可以通过命名空间来访问这些代码:
```typescript
MyNamespace.myFunction();
console.log(MyNamespace.myVariable);
```
需要注意的是,命名空间可以嵌套,例如:
```typescript
namespace OuterNamespace {
export namespace InnerNamespace {
export function myFunction(): void {
// ...
}
}
}
```
在实际使用中,我们可以通过命名空间来访问嵌套的代码:
```typescript
OuterNamespace.InnerNamespace.myFunction();
```
总的来说,`declare module` 用于声明模块或库的类型定义,而 `namespace` 用于组织代码。在实际使用中,我们可以根据需要选择适合的关键字来组织我们的代码结构。
阅读全文