TypeScript命名空间合并讲解

 更新时间:2021年12月30日 10:37:22   作者:LBJ  
这篇文章主要介绍了TS命名空间合并讲解,回顾上一节的内容,在上一节中我们介绍了TS中最常见的声明合并:接口合并,今天要讲的内容也是TS中的声明合并,但这次是命名空间相关的合并,需要的朋友可以参考一下

前言:
回顾上一节的内容,在上一节中我们介绍了TS中最常见的声明合并:接口合并

我们从中了解了声明合并其实指的就是编译器会针对同名的声明合并为一个声明,合并的结果是合并后的声明会同时拥有原先两个或多个声明的特性

而接口合并的合并需要里面的成员是否有函数成员。对于里头的函数成员来说,每个同名函数声明都会被当成这个函数的一个重载,当接口 A与后来的接口 A合并时,后面的接口具有更高的优先级

今天要讲的内容也是TS中的声明合并,但这次是命名空间相关的合并

主要分两方面来讲,一是同名的命名空间之间的合并,二是命名空间和其他类型的合并。下面会一一讲述

同名的命名空间之间的合并

与接口合并相类似,两个或多个同名的命名空间也会合并其成员

那具体怎么合并呢?

对于同名的命名空间之间的合并,记住一下4点:

  • 里头模块导出的同名接口会合并为一个接口
  • 对于非导出成员,仅在其原有的(合并前的)命名空间内可见。也就是说合并之后,从其它命名空间合并进来的成员无法访问非导出成员
  • 对于里头值的合并,如果里头值的名字相同,那么后来的命名空间的值会优先级会更高
  • 对于没有冲突的成员,会直接混入

例如:

namespace Animals {
    export class Cat { }
}

namespace Animals {
    export interface Legged { numberOfLegs: number; }
    export class Dog { }
}


等同于:

namespace Animals {
    export interface Legged { numberOfLegs: number; }

    export class Cat { }
    export class Dog { }
}


上述例子中,两个同名的命名空间Animals,最终合并为一个命名空间,而且结果是三个没有冲突的东西,直接混合在一起了

命名空间和其他类型的合并

命名空间可以与其它类型的声明进行合并,比如与类和函数,比如和枚举类型

合并同名的命名空间和类

例如:

class Album {
    label: Album.AlbumLabel;
}
namespace Album {
    export class AlbumLabel { }//导出 `AlbumLabel`类,好让合并的类能访问
}


命名空间和类的合并,结果是一个类并带有一个内部类

合并同名的命名空间和函数

除了上述的内部类的模式,你在JavaScript里,创建一个函数稍后扩展它增加一些属性也是很常见的。 TypeScript使用声明合并来达到这个目的并保证类型安全

例如官方的一个例子:

function buildLabel(name: string): string {
    return buildLabel.prefix + name + buildLabel.suffix;
}

namespace buildLabel {
    export let suffix = "";
    export let prefix = "Hello, ";
}

console.log(buildLabel("Sam Smith"));


同名的命名空间和枚举

可以用来扩展枚举,还是看官方给的例子吧

enum Color {
    red = 1,
    green = 2,
    blue = 4
}

namespace Color {
    export function mixColor(colorName: string) {
        if (colorName == "yellow") {
            return Color.red + Color.green;
        }
        else if (colorName == "white") {
            return Color.red + Color.green + Color.blue;
        }
        else if (colorName == "magenta") {
            return Color.red + Color.blue;
        }
        else if (colorName == "cyan") {
            return Color.green + Color.blue;
        }
    }
}

注意:
并不是所有东西都能合并,需要注意:类不能与其它类或变量合并

到此这篇关于TS命名空间合并讲解的文章就介绍到这了,更多相关TS命名空间合并内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 详解bootstrap导航栏.nav与.navbar区别

    详解bootstrap导航栏.nav与.navbar区别

    本篇文章主要介绍了详解bootstrap导航栏.nav与.navbar区别,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-11-11
  • 拖动时防止选中

    拖动时防止选中

    本文主要介绍了拖动时防止选中的小知识点。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-02-02
  • JavaScript forEach方法用法示例实战

    JavaScript forEach方法用法示例实战

    本文将详细介绍forEach方法的基本概念、用法、常见的应用场景、与其他遍历方法的对比,并提供实战示例,帮助您全面掌握这一强大的工具,感兴趣的朋友跟随小编一起看看吧
    2025-06-06
  • javascript 事件查询综合 推荐收藏

    javascript 事件查询综合 推荐收藏

    javascript 事件查询综合,需要的朋友可以参考下。
    2010-03-03
  • JS实现Select的option上下移动的方法

    JS实现Select的option上下移动的方法

    这篇文章主要介绍了JS实现Select的option上下移动的方法,涉及JavaScript动态操作页面元素的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2016-03-03
  • 让多个输入框中的内容同时变化的js代码

    让多个输入框中的内容同时变化的js代码

    怎么样让多个输入框中的内容同时变化?一般又要兼容IE与firefox
    2010-01-01
  • JavaScript取消Promise操作的常见实现方式

    JavaScript取消Promise操作的常见实现方式

    在 JavaScript 中,Promise 本身没有内置的取消机制,但我们可以通过一些模式来实现类似取消的功能,以下是几种常见的实现方式,需要的朋友可以参考下
    2025-10-10
  • 如何通过IntersectionObserver实现懒加载

    如何通过IntersectionObserver实现懒加载

    这篇文章主要介绍了通过IntersectionObserver实现懒加载,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-04-04
  • 使用Ajax与服务器(JSON)通信实例

    使用Ajax与服务器(JSON)通信实例

    本篇文章主要介绍了使用Ajax与服务器(JSON)通信方法,Ajax提供了两类服务器通信手段:同步通信和异步通信。有需要的可以了解一下。
    2016-11-11
  • 使用js在layui中实现上传图片压缩

    使用js在layui中实现上传图片压缩

    这篇文章主要介绍了使用js在layui中实现上传图片压缩,layui 是一款采用自身模块规范编写的前端 UI 框架,js上传图片压缩百度有很多方法,,需要的朋友可以参考下
    2019-06-06

最新评论