首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

TypeScript 之模块

模块(Module) JavaScript 有一个很长的处理模块化代码的历史,TypeScript 从 2012 年开始跟进,现在已经实现支持了很多格式。...TypeScript 中的模块(Modules in TypeScript) 在 TypeScript 中,当写一个基于模块的代码时,有三个主要的事情需要考虑: 语法:我想导出或者导入该用什么语法?...TypeScript 具体的 ES 模块语法(TypeScript Specific ES Module Syntax) 类型可以像 JavaScript 值那样,使用相同的语法被导出和导入: // @...TypeScript 模块解析选项(TypeScript’s Module Resolution Options) 模块解析是从 import 或者 require 语句中取出字符串,然后决定字符指向的是哪个文件的过程...TypeScript 命名空间(TypeScript namespaces) TypeScript 有它自己的模块格式,名为 namespaces 。它在 ES 模块标准之前出现。

1.1K00
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    模块_TypeScript笔记13

    一.语法格式 TypeScript 兼容 ES Module 规范,文件即模块 简单来讲,如果一个文件中含有合法的import或export语句,就会被当做模块(拥有模块作用域),否则就将在运行在全局作用域下...P.S.import/export具体语法见ES Module,这里不展开 CommonJS 模块支持 为了支持CommonJS 和 AMD 模块,TypeScript 提供了一种特殊语法: export...如果将来新版本 ES 规范中模块定义有改动的话,还会新增es2019, es2020...等值,对应 ES 规范各个版本中的模块定义(如果模块定义没有改动的话,就不加) P.S.具体的模块生成示例,见Code...因为完全可以编译生成满足 ES6 模块格式的 ES5 代码,例如: // tsconfig.json "compilerOptions": { "target": "es5", "module"...text 结尾的模块的类型 declare module "*!

    70720

    快速学习TypeScript——模块

    TypeScript也沿用这个概念 模块在其自身的作用域里执行,而不是在全局作用域里;这意味着定义在一个模块里的变量,函数,类等等在模块外部是不可见的,除非你明确地使用export形式之一导出它们。...大家最熟知的JavaScript模块加载器是服务于Node.js的 CommonJS和服务于Web应用的Require.js TypeScript与ECMAScript 2015一样,任何包含顶级import...这里的对象一词指的是类,接口,命名空间,函数或枚举 若使用export =导出一个模块,则必须使用TypeScript的特定语法import module = require("module")来导入此模块...在TypeScript里,使用下面的方式来实现它和其它的高级加载场景,我们可以直接调用模块加载器并且可以保证类型完全 编译器会检测是否每个模块都会在生成的JavaScript中用到。...库 要想描述非TypeScript编写的类库的类型,我们需要声明类库所暴露出的API 我们叫它声明因为它不是“外部程序”的具体实现。

    1.2K10

    【原创】TypeScript中的类和模块

    TypeScript中定义类 TypeScript中定义类使用class关键字,关键字后紧跟类名。类描述了构建对象共同的属性和方法。...并在字符串中使用${}进行属性的使用。 类中的属性和方法也可以使用public和private等修饰符进行对属性和方法的访问控制。...TypeScript中类的继承 继承是指子类继承父类的特征和行为(属性和方法),使得子类具有父类相同的特征和行为。TypeScript中使用extends关键字完成对类的继承。...} } //开始调用 let employee = new Employee('张三',18,'陕西西安'); console.log(employee.getEmployee()); TypeScript...中的模块 项目中可以将代码拆分为多个文件,多个文件可以互相加载,并通过export和import关键字完成模块功能的交换(从一个模块调用另外一个模块的函数)。

    14410

    深入理解 TypeScript 模块

    模块解析 ---- Typescript 模块解析就是指导 ts 编译器查找 import 导入内容的流程。TypeScript 共有两种可用的模块解析策略:Classic 和 Node 。...11.自定义模块解析策略 ---- tsconfig.json 中的 compilerOptions 是我们用的最多,也是最复杂的配置。其中有两种方式来自定义模块解析策略。...# 业务模块 │ │ ├── xxx │ │ │ ├── a.ts └── tsconfig.json tsconfig.json 配置如下: { "compilerOptions...并且详细描述了 TypeScript 模块解析的流程,解析过程中文件的优先级策略等等,让大家对 TypeScript 模块有了一个全面的认识。...参考 TypeScript 官方文档 TypeScript 中文手册 TypeScript 模块 了不起的 tsconfig.json 指南

    2.5K30

    开心档之TypeScript 模块

    TypeScript 模块 TypeScript 模块的设计理念是可以更换的组织代码。...类似地,我们必须通过 import 导入其他模块导出的变量、函数、类等。 两个模块之间的关系是通过在文件级别上使用 import 和 export 建立的。 模块使用模块加载器去导入其它的模块。...在运行时,模块加载器的作用是在执行此模块代码前去查找并执行这个模块的所有依赖。...类似地,我们必须通过 import 导入其他模块导出的变量、函数、类等。 两个模块之间的关系是通过在文件级别上使用 import 和 export 建立的。 模块使用模块加载器去导入其它的模块。...在运行时,模块加载器的作用是在执行此模块代码前去查找并执行这个模块的所有依赖。

    29220

    TypeScript 模块导入那些事

    ES6 模块导入的限制 我们先来看一个具体的例子: 在 Node 项目里,使用 CommonJS 规范引入一个模块: const koa = require('koa') 复制代码 改写为 TypeScript...' 复制代码 使用 TypeScript 模块导入语法: import koa = require('koa') 复制代码 两者大部分是等价的,但 ES6 规范对 import * as 创建出的模块对象有一点限制...2.7 版本对 CommonJs/AMD/UMD 模块导入的增强 在之前的版本,TypeScript 对 CommonJs/AMD/UMD 模块的处理方式与 ES6 模块相同,这会导致一些问题: 如前文所提到的...在 2.7 的版本里,TypeScript 提供了一个新选项 --esModuleInterop,旨在解决上述问题, 当使用该选项,且模块为 CommonJs/AMD/UMD 时,它会导入一个可调用或是可实例化的模块...实际上,当我们导入一个模块时: import koa from 'koa' // import koa = require('koa') 复制代码 它所做的事情只有两个: 导入模块的所有类型信息; 确定运行时的依赖关系

    2K30

    TypeScript系列教程十《模块》

    TypeScript 从2012年开始,已经支持了大部分的格式,但随着时间的推移,社区和JavaScript规范已经融合到一种称为ES模块(或ES6模块)的格式上。...无论您的模块目标是什么,此语法都有效。 TypeScript 中的模块 在TypeScript编写基于模块的代码时,需要考虑三个主要问题: 语法: 我想使用什么语法来导入和导出内容?...TypeScript的模块解析选项 模块解析是从import或require语句中获取字符串,并确定该字符串引用的文件的过程。 TypeScript包括两种解析策略:Classic和Node。...例如,下面是一个使用ES模块语法的TypeScript文件,展示了模块的几个不同选项: import { valueOfPi } from "....TypeScript 命名空间 TypeScript有自己的名为名称空间的模块格式,它早于ES模块标准。

    1.5K10

    TypeScript Project References npm 包构建小实践

    npm 包输出 es/cjs 产物 在开发一个 npm 包时,通常需要同时输出 ES 模块和 CommonJS 模块的产物供不同的构建进行使用。...", } } 通过运行 npm run build,可以生成同时包含 ES 模块和 CommonJS 模块的产物 TypeScript 的 references 是什么 TypeScript 的项目引用...(Project References)是 TypeScript 3.0 引入的一项功能,允许一个 TypeScript 项目引用另一个 TypeScript 项目。...模块化:通过项目引用,可以将代码库拆分为多个独立的、可复用的模块,提升代码的可维护性和可读性。 类型安全:项目引用确保了项目之间的类型安全,避免了类型不一致的问题。...在这个场景下 TypeScript 会根据项目引用的配置,自动构建 ES 模块和 CommonJS 模块,并且只会重新编译发生变化的部分,从而提升增量编译的性能

    11910

    TypeScript 中命名空间与模块的区别

    一、模块 TypeScript 与 ECMAScript 2015 一样,任何包含顶级 import 或者 export 的文件都被当成一个模块 相反地,如果一个文件不带有顶级的import或者export...声明,那么它的内容被视为全局可见的 例如我们在在一个 TypeScript 工程下建立一个文件 1.ts,声明一个变量a,如下: const a = 1 然后在另一个文件同样声明一个变量a,这时候会出现错误信息...提示重复声明a变量,但是所处的空间是全局的 如果需要解决这个问题,则通过import或者export引入模块系统即可,如下: const a = 10; export default a 在typescript...但就像其它的全局命名空间污染一样,它很难去识别组件之间的依赖关系,尤其是在大型的应用中 像命名空间一样,模块可以包含代码和声明。...不同的是模块可以声明它的依赖 在正常的TS项目开发过程中并不建议用命名空间,但通常在通过 d.ts 文件标记 js 库类型的时候使用命名空间,主要作用是给编译器编写代码的时候参考使用 参考文献

    18410

    模块解析机制_TypeScript笔记14

    写在前面 模块化机制让我们能够把代码拆分成多个模块(文件),而编译时需要知道依赖模块的确切类型,那么首先要找到它(建立模块名到模块文件路径的映射) 实际上,在 TypeScript 里,一个模块名可能对应一个...用来引入外部依赖模块 二.模块解析策略 具体的,有 2 种模块解析策略: Classic:TypeScript 默认的解析策略,目前仅用作向后兼容 Node:与 NodeJS 模块机制一致的解析策略 这..."Node"时)TypeScript 也会模拟NodeJS 运行时的模块解析机制,以便在编译时找到模块的定义文件 具体的,会把 TypeScript 源文件后缀名加到 NodeJS 的模块解析逻辑上,还会通过...因此,在运行时模块可能具有不同于源文件的命名,或者编译时最后输出的模块路径与对应的源文件不匹配 针对这些问题,TypeScript 提供了一系列标记用来告知编译器期望发生在源路径上的转换,以生成最终输出...TypeScript 同样支持类似的映射配置(tsconfig.json的paths字段),例如: { "compilerOptions": { "baseUrl": "

    1.7K30
    领券