广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >TypeScript命名空间合并讲解
  • 444
分享到

TypeScript命名空间合并讲解

2024-04-02 19:04:59 444人浏览 薄情痞子
摘要

目录同名的命名空间之间的合并 命名空间和其他类型的合并 合并同名的命名空间和类 合并同名的命名空间和函数 同名的命名空间和枚举 前言: 回顾上一节的内容,在上一节中我们介绍了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命名空间合并内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: TypeScript命名空间合并讲解

本文链接: https://www.lsjlt.com/news/161236.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • TypeScript命名空间合并讲解
    目录同名的命名空间之间的合并 命名空间和其他类型的合并 合并同名的命名空间和类 合并同名的命名空间和函数 同名的命名空间和枚举 前言: 回顾上一节的内容,在上一节中我们介绍了TS中最...
    99+
    2022-11-12
  • TypeScript命名空间讲解
    目录1.定义和使用 1.1定义 1.2使用 2.拆分为多个文件 3.别名 前言: 命名空间namespace在TypeScript1.5版本之前是叫做内部模块 ,那是因为ES6中的...
    99+
    2022-11-12
  • C++ 命名空间详解
    目录一、C++ 命名空间1.默认NameSpace(Global&Function)2.语法规则1.声明 2.使用方法3.支持嵌套总结一、C++ 命名空间 命名空间...
    99+
    2022-11-12
  • C++的命名空间详解
    目录C++ | C++命名空间C++命名空间定义命名空间实例1:using 指令实例2:实例3:不连续的命名空间嵌套的命名空间实例4:实例5:笔记:实例6:实例7:总结C++ | C...
    99+
    2022-11-12
  • C++namespace命名空间解析
    目录命名空间 namespace命名空间的定义1. 函数定义在命名空间里2.对全局变量使用命名空间3.命名空间的嵌套4.using命名空间5.命名空间里的结构体命名空间 namesp...
    99+
    2022-11-12
  • C++命名空间namespace详解
    目录一、命名空间的定义1.一般定义2.嵌套定义3.重名定义二、命名空间的使用1.命名空间的名称及作用域限定符2.使用using namespace 命名空间全展开3.使用using引...
    99+
    2023-05-14
    命名空间 namespace c++ 命名空间 namespace
  • TypeScript模块与命名空间的关系和使用方法
    目录一、模块1. 全局模块2. 文件模块3. 模块规范二、命名空间三、文件模块和命名空间的关系一、模块 1. 全局模块 在默认情况下,当你开始在一个新的 TypeScript 文件中...
    99+
    2023-03-09
    TypeScript模块 TypeScript命名空间
  • C#命名空间怎么理解
    这篇文章主要介绍“C#命名空间怎么理解”,在日常操作中,相信很多人在C#命名空间怎么理解问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C#命名空间怎么理解”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!从C...
    99+
    2023-06-17
  • 详解PHP中的命名空间
    命名空间其实早在PHP5.3就已经出现了。不过大部分同学可能在各种框架的使用中才会接触到命名空间的内容,当然,现代化的开发也都离不开这些能够快速产出的框架。这次我们不从框架的角度,仅...
    99+
    2022-11-12
  • Linux的命名空间如何理解
    小编今天带大家了解Linux的命名空间如何理解,文中知识点介绍的非常详细。觉得有帮助的朋友可以跟着小编一起浏览文章的内容,希望能够帮助更多想解决这个问题的朋友找到问题的答案,下面跟着小编一起深入学习“Linux的命名空间如何理解”的知识吧。...
    99+
    2023-06-29
  • C++学习之命名空间详解
    目录1.命名空间的定义和使用2.命名空间嵌套3.命名空间别名4.标准命名空间总结C++中,命名空间(namespace)是一个重要的概念。命名空间可以为函数、变量、类等定义作用域,以...
    99+
    2023-05-18
    C++命名空间定义 C++命名空间使用 C++命名空间
  • TypeScript模块与命名空间的关系和使用方法是什么
    这篇文章主要讲解了“TypeScript模块与命名空间的关系和使用方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“TypeScript模块与命名空间的关系和使用方法是什么”吧!一、模...
    99+
    2023-07-05
  • C++内存模型与名称空间概念讲解
    目录1、存储持续性与作用域及链接性2、作用域和链接3、静态持续变量4、静态持续性和外部链接性5、静态持续性与内部链接性6、静态存储性与无链接性7、const8、函数和链接性9、语言的...
    99+
    2023-01-02
    C++内存模型 C++名称空间
  • win7磁盘空间分离与磁盘空间合并方法图解
    为了在某某系统下安装多个系统或者纯粹分多一个磁盘空间出来,我们需要知道如何分离磁盘空间,可是当我们分离空间后突然后悔,想要把空间合并回去怎么办呢?不用着急,下面就为大家介绍win7磁盘空间分离与磁盘空间合并方法,希望能帮...
    99+
    2023-06-06
    win7磁盘空间分离 win7磁盘空间合并 磁盘空间 合并 win7 方法
  • jQuery中绑定事件的命名空间详解
    在没有看到这篇 文章之前,我一直不知道原来bind也可以有命名空间。事实上,我看完这篇文章后,再去翻了一下手册,也才发现了一点点的注释。但手册也仅仅是一句话就带 过去了。没有过多的深...
    99+
    2022-11-21
    jQuery 绑定事件
  • 如何理解PHP核心特性命名空间
    目录提出定义使用限定符在内部访问命名空间转义\符号提出 PHP 在 5.3 后提出了命名空间用来解决组件之间的命名冲突问题,主要参考了文件系统的设计: 同一个目录下不允许有...
    99+
    2022-11-12
  • 怎样解析.NET 程序集与命名空间
    本篇文章为大家展示了怎样解析.NET 程序集与命名空间,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。程序集程序集(assembly)是一个或多个托管模块,以及一些资源文件的逻辑组合。组成部分Wind...
    99+
    2023-06-17
  • thinkphp命名空间失效问题怎么解决
    本篇内容主要讲解“thinkphp命名空间失效问题怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“thinkphp命名空间失效问题怎么解决”吧!原因:引入文件错误:有时可能会因为引入的文件...
    99+
    2023-07-05
  • 详解Python 中的命名空间、变量和范围
    目录Python 中的命名空间、变量和范围什么是命名空间?变量和表达式变量范围Python 中的命名空间、变量和范围 什么是命名空间? 首先,我们需要感知python中的名称(标识符...
    99+
    2022-11-11
  • 示例详解C++语言中的命名空间 (namespace)
    目录前言1. 命名空间 2. using 指令 3. 不连续的命名空间 4. 嵌套的命名空间 5. 命名空间内变量、函数、全局变量的作用域5.1 using namespace fi...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作