nodejs require/import导包报错以及解决方法


背景

最近发现一本nodejs的小册,在学习其中的代码时,发现里面用到了chalk-animation这个库,在install好这个库后,使用require()导入时报错

Error [ERR_REQUIRE_ESM]: require() of ES Module E:/.../code/node_modules/chalk-animation/index.js from E:/.../code/案例一.js not supported.
Instead change the require of index.js in E:/.../code/案例一.js to a dynamic import() which is available in all CommonJS modules.

由于这本小册写于多年前,现在这个库最新版已经变成了ESModule导出了,看到报错信息,貌似已经支持了全部的CommonJS模块使用import导入,果断改成import导入方式。这时候再来运行代码,控制台又爆出如下错误:

import chalkWorker from 'chalk-animation'
^^^^^^

SyntaxError: Cannot use import statement outside a module

这是由于没有声明包类型导致的

解决方案

打开package.json,在其中声明包类型为module,如下所示

{
  "devDependencies": {
    "chalk-animation": "^2.0.3"
  },
  "type": "module"
}

type还可以设置为commomjs,这个是默认的(V18.4)。

意外事故

有这么两个文件

//step.js
const pad = '.'
exports.step = (t)=>`|${pad.repeat(t)}>>`
//race.js
const { step } = require("./step.js")
const steps = step(20)
module.exports = { steps }

在设置为module后,原先js文件中module.exports的方式就不支持了。会报如下错误

const { step } = require("./step.js")
                 ^

ReferenceError: require is not defined in ES module scope, you can use import instead
This file is being treated as an ES module because it has a '.js' file extension 
and 'E:/.../code/package.json' contains "type": "module".
To treat it as a CommonJS script, rename it to use the '.cjs' file extension.

根据报错信息提示,我们可以使用两种方法来修改代码。

  • 使用import的方式来代替require
//导入的改变
// const { step } = require("./step.js")
import { step } from "./step.js"

//导出也要改变
//exports.step = (t)=>`|${pad.repeat(t)}>>`
export function step(t){ return `|${pad.repeat(t)}>>`}
  • 把文件拓展名改为.cjs,这样它会被当作commonJs来对待

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/288974.html

(0)
上一篇 2022年9月12日
下一篇 2022年9月12日

相关推荐

发表回复

登录后才能评论