TypeScript模块导入终极解决方案

在这里插入图片描述
在使用TypeScript导入一般的第三方模块时,因为兼容了es6、es7的语法,所以一般在typescirpt中可以使用 import、export 的方式来导入导出模块ts模块。但是使用ts写nodejs的代码时,这样就有问题,因为nodejs采用的是commonjs,所以这样两者就有冲突

使用commonjs的方式导入第三方模块:

const koa = require(‘koa’)
这种方式虽然没报错,但是这个里面还是有问题的。

使用es6的方式导入:

import {koa} from ‘koa’
这种方式会报错:koa’ is declared but its value is never read

解决方案

ts是用来用来做类型检测的,使用ts来开发nodejs其实只是使用了其中的语法特点,来完成编写,并且最终也要编译成其他语法结构的代码。
tsconfig.json:
在这里插入图片描述
可以看出这里还是会编译成commonjs的代码。

  • 导入ts模块要进行类型检测,但是使用import导入模块时要进行类型检测,因为一般像koa的模块没有ts文件,使用的commonjs导出的js模块,所以没法用ts进行类型检测,所以要使用声明文件来处理这个问题,网址
  • 一般声明文件只是项目开发时,编译器参照使用的,所以安装时,安装到开发依赖中
  • npm i @types/koa -D

  • 默认所有可见的"@types"包会在编译过程中被包含进来。 node_modules/@types文件夹下以及它们子文件夹下的所有包都是可见的; 也就是说, ./node_modules/@types/,…/node_modules/@types/和…/…/node_modules/@types/等等
  • 所以需要早tsconfig.json中配置,如果指定了typeRoots,只有typeRoots下面的包才会被包含进来
  • 注意:若使用export =导出一个模块,则必须使用TypeScript的特定语法import module = require(“module”)来导入此模块。

tsconfig.json配置
在这里插入图片描述
这里也可以包含自己的写的声明文件如@types

最终效果

在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
TypeScript是JavaScript的一个超集,它添加了静态类型检查和其他一些语言特性。在使用TypeScript时,我们可以使用模块来组织我们的代码。 模块是一个独立的、封装的代码单元,它可以被导出、导入和复用。通过使用模块,我们可以更好地组织代码,使其更具可维护性和可扩展性。 在TypeScript中,我们可以使用关键字`export`来导出一个模块,使用`import`来导入一个模块。例如,我们可以创建一个名为`math.ts`的模块,其中包含两个函数`add`和`subtract`,并将其导出: ``` // math.ts export function add(a: number, b: number): number { return a + b; } export function subtract(a: number, b: number): number { return a - b; } ``` 我们可以在另一个文件中导入这个模块,并使用它的函数: ``` // app.ts import { add, subtract } from './math'; console.log(add(1, 2)); // 3 console.log(subtract(3, 2)); // 1 ``` 注意,在上面的例子中,我们使用相对路径`./math`来指定要导入模块。这是因为我们将`math.ts`文件和`app.ts`文件放在同一个目录下。如果我们将`math.ts`文件放在不同的目录中,我们需要使用相对于根目录的路径或绝对路径来导入模块。 除了使用`export`和`import`关键字之外,TypeScript还支持`export default`语法来导出一个默认的模块。例如,我们可以将`math.ts`文件中的`add`函数作为默认导出: ``` // math.ts export default function add(a: number, b: number): number { return a + b; } ``` 我们可以在另一个文件中使用`import`关键字来导入默认模块: ``` // app.ts import add from './math'; console.log(add(1, 2)); // 3 ``` 请注意,我们在导入默认模块时不需要使用花括号。 这是一些关于TypeScript模块的基本概念,希望对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值