Pra*_*vel 10 typescript reactjs webpack babel-loader
我正在开发一个使用 create-react-app 构建的 React 项目,后来我们弹出并修改了很多 webpack 配置。现在我很难const enums
从外部库导入。我无法控制该外部包。它在其文件中定义了常量枚举d.ts
。
我尝试过babel-plugin-use-const-enum
babel 插件和预设。这对我也没有帮助。
我的网络包配置:
.....
.....
{
test: /\.(js|mjs|jsx|ts|tsx)$/,
include: [paths.appSrc],
loader: require.resolve("babel-loader"),
options: {
customize: require.resolve("babel-preset-react-app/webpack-overrides"),
plugins: [
[require.resolve("babel-plugin-const-enum"), { transform: "constObject" }],
[require.resolve("@babel/plugin-transform-typescript"), { isTSX: true, optimizeConstEnums: true }],
[require.resolve("@babel/plugin-transform-react-jsx")],
[require.resolve("@babel/plugin-proposal-class-properties"), { loose: true }],
[require.resolve("@babel/plugin-proposal-nullish-coalescing-operator")],
[require.resolve("@babel/plugin-proposal-optional-chaining"), { isTSX: true }],
[require.resolve("@babel/plugin-transform-arrow-functions")],
[require.resolve("@babel/plugin-proposal-private-methods"), { loose: true }],
[
require.resolve("babel-plugin-named-asset-import"),
{
loaderMap: {
svg: {
ReactComponent: "@svgr/webpack?-svgo,+titleProp,+ref![path]",
},
},
},
],
],
presets: ["@babel/preset-env"],
},
},
.....
.....
Run Code Online (Sandbox Code Playgroud)
我的 tsconfig:
{
"compilerOptions": {
"typeRoots": ["./typings", "node_modules/@types"],
"target": "es5",
"lib": ["dom", "dom.iterable", "esnext"],
"allowJs": true,
"skipLibCheck": true,
"esModuleInterop": true,
"allowSyntheticDefaultImports": true,
"strict": true,
"forceConsistentCasingInFileNames": true,
"module": "esnext",
"moduleResolution": "node",
"resolveJsonModule": true,
"noEmit": true,
"jsx": "react",
"downlevelIteration": true
},
"exclude": ["dist/**/*"],
}
Run Code Online (Sandbox Code Playgroud)
问题是构建成功,但我面临所有 const 枚举导入的运行时问题,如下所示
Uncaught TypeError: Cannot read properties of undefined (reading '<ConstEnumName>')
。
封装版本:
"@babel/core": "^7.11.6",
"babel-loader": "^8.1.0",
"typescript": "^3.9.7",
"webpack": "^4.44.2",
Run Code Online (Sandbox Code Playgroud)
根据此线程,涉及插件创建者,babel 不会转译.d.ts
文件,因此无法从那里获取枚举。唯一的选择似乎是迁移您的配置以使用ts-loader
并包含.d.ts
具有枚举声明的文件
tsconfig
{
...
"exclude": ["dist/**/*"],
"include": ["node_modules/[external_library]/**/*.d.ts"],
}
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
1790 次 |
最近记录: |