Typescript - 将命名空间A导入另一个命名空间B作为B的子命名空间,并全局暴露命名空间B
创始人
2024-05-30 15:03:13

前言

最近相统一管理 ts 中的类型声明,这就需要将各模块下的命名空间整合到全局的命名空间下,牵涉到从别的文件中引入命名空间并作为子命名空间在全局命名空间中统一暴露。

将命名空间A导入另一个命名空间B作为B的子命名空间

  • 文件说明
    assets.ts 文件中有包含资产相关类型声明的命名空间 Assets

    export namespace Assets {export interface TV {id: number;price: string;}
    }
    

    global.ts 文件中有全局统一暴露的命名空间 GlobalType

    export namespace GlobalType {export interface User {prop: string;}
    }
    
  • 需求:将 Assets 作为 GlobalType 的子命名空间

    import { Assets } from './assets';export namespace GlobalType {export import $Asstes = Assets; // 这里就将 Assets 命名空间作为 GlobalType 的子命名空间了export interface User {prop: string;}
    }
    

全局暴露命名空间B

  • index.d.ts

    import { GlobalType } from '/global';export = GlobalType;
    export as namespace GlobalType;
    

文件中直接使用全局命名空间进行类型声明

  • test.ts

    const TV1: GlobalType.Assets.TV = {id: 001,price: '¥3888'
    } // ts 检验通过const TV2: GlobalType.Assets.TV = {id: 002,
    } // 提示没有 price 属性
    

相关内容

热门资讯

特写 | 森马服饰郭云鹏:品牌... 观点网 当出海从一道选择题变成必答题,中国消费品牌的全球叙事正经历深刻重构。不同于早期简单的产品输出...
阿联酋外长与国际原子能机构总干... 转自:财联社【阿联酋外长与国际原子能机构总干事就无人机袭击事件通电话】财联社5月18日电,阿联酋副总...
养老院“专属家人”13年义剪还...     毛寅在养老院帮老人义剪头发。      受访者 供图  “毛老师来了!”5月16日上午,长沙...
强降雨持续 注意防范山洪...   三湘都市报5月17日讯  据气象预报,我省未来三天强降雨持续,局地单点有大暴雨。省应急委办公室提...
深圳一季度实际使用外资约170... 界面新闻记者 | 梁宝欣4月28日,界面新闻记者从深圳市投资促进局了解到,今年一季度,深圳实际使用外...