Я обновился до Webpack 4 с 3. С тех пор я получаю много предупреждений относительно импорта, который не был экспортирован из определенных файлов.
./packages/utils/logging/index.ts
Attempted import error: ‘Options' is not exported from './loggers/log'.
@ ./packages/utils/index.ts
@ ./src/App.tsx
@ multi whatwg-fetch @babel/polyfill ./src/App.tsx
Я использую ts-loader
вместе с ForkTsCheckerWebpackPlugin
.Я изучил экспорт из предупреждений, и они выглядят хорошо.Код работает, но я все еще получаю эти предупреждения.
tsconfig.json
для справки:
{
"compilerOptions": {
"outDir": "build/dist",
"module": "esnext",
"target": "es5",
"lib": ["es6", "dom"],
"baseUrl": ".",
"sourceMap": true,
"allowJs": true,
"jsx": "react",
"moduleResolution": "node",
"forceConsistentCasingInFileNames": true,
"noImplicitReturns": true,
"noImplicitThis": true,
"strictNullChecks": true,
"suppressImplicitAnyIndexErrors": true,
"noUnusedLocals": false,
"noUnusedParameters": false,
"allowSyntheticDefaultImports": true,
"skipLibCheck": true,
"resolveJsonModule": true
},
"include": ["packages/**/*"],
"exclude": [
"node_modules",
"build",
"scripts",
"webpack",
"**/__tests__/*"
]
}
Конфигурация Webpack:
...
module: {
rules: [
{
test: /\.(ts|tsx|d.ts)$/,
exclude: /node_modules/,
use: {
loader: 'ts-loader',
options: {
transpileOnly: true,
},
},
},
{
test: /\.(js|jsx|mjs)$/,
include: [paths.packagesSrc, ...paths.modulesToTranspile],
exclude: /node_modules/,
use: {
loader: 'babel-loader?cacheDirectory=true',
options: {
configFile: paths.configFiles.babel,
},
},
},
...
]
},
plugins: [
...
new ForkTsCheckerWebpackPlugin({
async: options.asyncTypeChecking,
checkSyntacticErrors: true,
tsconfig: paths.appTsConfig,
watch: paths.packagesSrc,
}),
...
],
...