背景
最近发现一本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