首页
学习
活动
专区
圈层
工具
发布

TypeScript 之模块

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

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

    模块_TypeScript笔记13

    一.语法格式 TypeScript 兼容 ES Module 规范,文件即模块 简单来讲,如果一个文件中含有合法的import或export语句,就会被当做模块(拥有模块作用域),否则就将在运行在全局作用域下...为了支持CommonJS 和 AMD 模块,TypeScript 提供了一种特殊语法: export = something; 用来定义一个模块的导出对象,类似于 NodeJS 里的: // NodeJS...模块(CommonJS) let x = {a: 1}; exports.x = x; module.exports = x; 改写成 TypeScript 的话是这样: let x = {a: 1};...如果将来新版本 ES 规范中模块定义有改动的话,还会新增es2019, es2020...等值,对应 ES 规范各个版本中的模块定义(如果模块定义没有改动的话,就不加) P.S.具体的模块生成示例,见Code.../templates/start.html'; // 正确 html.trim(); UMD 模块 UMD的特点是既兼容 CommonJS 和 AMD 模块加载,也可以暴露到全局直接使用,因此其模块声明也比较特殊

    89020

    快速学习TypeScript——模块

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

    1.5K10

    深入理解 TypeScript 模块

    模块解析 ---- Typescript 模块解析就是指导 ts 编译器查找 import 导入内容的流程。TypeScript 共有两种可用的模块解析策略:Classic 和 Node 。.... ▐ 9.4 TypeScript 的 Node 模块解析和 Node.js 有何区别 当使用 Node 模块解析策略是,TypeScript 是模仿 Node.js 运行时的解析策略来在编译阶段定位模块定义文件...总结 ---- 这篇文章讲述了 TypeScript 模块的概念及使用方式,知道了怎么定义一个全局模块和一个文件模块。...并且详细描述了 TypeScript 模块解析的流程,解析过程中文件的优先级策略等等,让大家对 TypeScript 模块有了一个全面的认识。...参考 TypeScript 官方文档 TypeScript 中文手册 TypeScript 模块 了不起的 tsconfig.json 指南

    3K30

    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 模块相同,这会导致一些问题: 如前文所提到的...类似的,当导入一个 CommonJs/AMD/UMD 模块时,TypeScript 视 import foo from 'foo' 与 const koa = require('koa').default...在 2.7 的版本里,TypeScript 提供了一个新选项 --esModuleInterop,旨在解决上述问题, 当使用该选项,且模块为 CommonJs/AMD/UMD 时,它会导入一个可调用或是可实例化的模块

    2.2K30

    TypeScript系列教程十《模块》

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

    1.9K10

    TypeScript 在 Vue 的实践

    前言 在 vue-cli 3.0 的脚手架出来以后,官方我们提供了一套 Vue 的 TypeScript 模板,解决了许多模块以及类型问题,官方的东西真香,因此可以使用 TypeScript 搞一波事情...在 TypeScript 中,不能再像原来一样写基于配置的 mixin 对象,而应该也写为一个 Vue 的子类: import { Vue, Component } from 'vue-property-decorator...如果只是 template 中使用方法,那么不需要强制断言 填坑指南 VScode 插件配置 TSLint Vue mixin 的相关配置 Vuex 方法的接口实现 复用接口的摆放位置 使用了 TypeScript...仍然是在运行时抛出 不过好消息是,Vue 3.0 将采用 TypeScript 重构,全新的 Vue 不仅带来性能上的提升,还会进一步提升对类型的支持。...未来,class-compoent 也将成为主流,现在写 TypeScript 以后进行 3.0 的迁移会更加方便。

    2.9K30

    Vue + TypeScript 踩坑总结

    vue 和 TypeScript 结合的情况下,很多写法和我们平时的写法都不太一样,这里总结我项目开发过程中遇到的问题和问题的解决方案 有些问题可能还没解决,欢迎各位大佬给与提点。...另外,使用本文前可以先看vue 官方文档关于 typescript 的使用讲解 整个 vue 项目的目录结构 大体用 vue-cli 创建的项目,结构基本不变。.../App.vue'处,找不到 App.vue 这个模块 解决方案: 1、将 shims-vue.d.ts 文件一分为二。...vue-cli 配置了 resolve alias 来声明的路径别名,在引用了 ts 后,vscode 会报错不能识别、模块查找失败。...scss路径引用 */ @import "css/_variable.scss"; 请求接口的代理设置 vue.config.js 配置 // vue.config.js module.exports

    5.5K20

    模块解析机制_TypeScript笔记14

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

    2.1K30
    领券