当我使用Typescript运行Jest测试时,在node_modules
库中调用的外部TS文件导入时出现以下错误:
SyntaxError: Cannot use import statement outside a module
我确定我缺少配置,但这是什么?感谢您的帮助。
这是我的配置:
tsconfig.json
{
"compilerOptions": {
"sourceMap": true,
"module": "commonjs",
"moduleResolution": "node",
"esModuleInterop": true,
"allowJs": true,
"jsx": "react",
"target": "es5",
"lib": ["dom", "dom.iterable", "esnext"],
"baseUrl": "./",
"paths": {
"*": ["src/*"]
}
},
"strict": true,
"module": "node",
"compileOnSave": false,
"include": ["src", "tests"]
}
jest.config.js
module.exports = {
roots: ['<rootDir>'],
preset: 'ts-jest',
testRegex: 'tests/.*\\.test.(js|jsx|ts|tsx)$',
transform: {
'^.+\\.tsx?$': 'ts-jest',
},
moduleFileExtensions: ['ts', 'tsx', 'js', 'jsx', 'json', 'node'],
moduleDirectories: ['node_modules', 'src'],
setupFilesAfterEnv: ['<rootDir>/tests/jest.setup.ts'],
collectCoverage: true,
collectCoverageFrom: ['src/**/*.{js{,x},ts{,x}}', '!src/index.tsx'],
}
webpack.config.js
/* eslint-disable @typescript-eslint/no-var-requires */
const path = require('path')
const webpack = require('webpack')
module.exports = {
entry: './src/index.tsx',
mode: 'development',
module: {
rules: [
{
test: /\.jsx?$/,
exclude: /node_modules/,
loader: 'babel-loader',
options: { presets: ['@babel/env'] },
},
{
test: /\.tsx?$/,
exclude: /node_modules/,
loader: 'ts-loader',
},
{
test: /\.css$/,
exclude: /node_modules/,
use: ['style-loader', 'css-loader'],
},
],
},
resolve: {
extensions: ['.js', '.jsx', '.ts', '.tsx'],
alias: { 'react-dom': '@hot-loader/react-dom' },
},
output: {
path: path.resolve(__dirname, 'dist/'),
publicPath: '/dist/',
filename: 'app.js',
},
devServer: {
contentBase: path.join(__dirname, 'public/'),
port: 3000,
publicPath: 'http://localhost:3000/dist/',
hotOnly: true,
},
plugins: [new webpack.HotModuleReplacementPlugin()],
}
答案 0 :(得分:1)
我遇到了同样的问题,请检查您导入的所有路径是否正确
就我而言,我有import NavbarCollapse from "react-bootstrap/esm/NavbarCollapse";
而不是import NavbarCollapse from "react-bootstrap/NavbarCollapse";
答案 1 :(得分:0)
我认为问题出在
"module": "node",
tsconfig.json中的行。删除它。您的compileOptions部分中具有正确的模块规范(commonjs)。