TS入门——06.命名空间

命名空间概述

命名空间就是用来开辟一个作用域解决命名冲突问题,我们可以在不同命名空间中定义同名的变量
TypeScript 使用namespace来定义命名空间,通过 export 关键字对外暴露需要在外部访问的对象,如下

namespace s1 {
  export interface rule {
    name: string,
    age: number
  }
}

// 使用命名空间s1的接口约束
const obj: s1.rule = {
  name: 'lucky',
  age: 22
}

上面代码定义了一个s1命名空间,向外暴露了rule接口,在外面想要使用命名空间里的接口只需通过点语法调用即可,要在另一个文件中使用该命名空间的内容就需要使用,则应使用三斜杠 /// 引用它,语法格式如下:

/// <reference path = “FileName.ts” /

假设上面代码是在namespace1.ts文件中,以下实现在同级目录下namespace2.ts中使用命名空间s1里的接口约束

/// <reference path="namespace1.ts" />

const obj2: s1.rule = {
  name: 'lucky',
  age: 22
}

命名空间的相互引入和导出使用案例

util.ts

namespace A {
  export interface personRule {
    name: string,
    sayHi () : string
  }
}

person.ts

/// <reference path="util.ts" />

export namespace B {
  export class Person implements A.personRule {
    public name: string
    constructor(name: string) {
      this.name = name
    }

    sayHi(): string {
      return this.name + '你好'
    }
  }
}

index.ts

import { B } from './person'

const me = new B.Person('lucky')
console.log(me.sayHi()) // lucky你好

命名空间到此结束

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值