Webpack 从使用 module.exports 的文件导入
我有 React 应用程序和一个文件,我想在其中存储与 api 相关的内容。
const proxy = require('http-proxy-middleware');
const path = require('path');
//.....
const targetApi = (objectWithUrlEntries) => {
Object.keys(objectWithUrlEntries).forEach((key) => {
objectWithUrlEntries[key] = path.join('/api/', objectWithUrlEntries[key]);
});
};
module.exports.proxyExpressCalls = proxyExpressCalls;
module.exports.devServerProxyConfig = devServerProxyConfig;
module.exports.targetApi = targetApi;
其中一些内容将由 webpack 本身使用,一些将在应用程序内部使用(以正确定位 api 调用)。
但是,当我尝试在我的应用程序中导入内容时:
// @flow
import { buildUrl } from 'data/utils';
import type { Axios } from './flow.types';
import { targetApi } from './api';
console.log(targetApi());
我收到错误。在终端中:
WARNING in ./src/data/redux/api/user.js 6:12-21 "export 'targetApi' was not found in './api'
在浏览器中:
api.js?d669:39 Uncaught TypeError: Cannot set property 'proxyExpressCalls' of undefined
at Object.eval (api.js?d669:39)
at eval (api.js:60)
at Object../src/data/redux/api/api.js (client.bundle.js:11620)
at __webpack_require__ (client.bundle.js:708)
at fn (client.bundle.js:113)
at eval (user.js:15)
at Object../src/data/redux/api/user.js (client.bundle.js:11668)
at __webpack_require__ (client.bundle.js:708)
at fn (client.bundle.js:113)
at eval (user.js:18)
因此问题是,当应用程序被捆绑时,
commonjs
导出会失败,但如果我使用 es6
export
语法,那么
Node
就会失败。
我遇到了类似的问题:我有一个 javascript 类,其中包含一些验证规则,我想在 Node JS 和客户端代码中使用这些规则。对我有用的方法是将所有内容转换为 Common JS、共享代码、节点代码和客户端代码。但我仍然遇到了一些问题。然后,我将
"module": "commonjs"
添加到导入共享代码的文件夹的 .babelrc 中,它终于起作用了。这是我的 .babelrc 文件:
{
"presets": [
"react",
[
"env",
{
"debug": true,
"modules": "commonjs",
"targets": {
"browsers": [
"last 2 versions",
"safari >= 7"
],
}
}
],
],
"plugins": [
"transform-object-rest-spread",
"transform-es2015-arrow-functions",
"transform-class-properties"
]
}
另一个可能的解决方案是(未经测试!)使用 webpack 从共享代码中创建一个库。检查 output.library 和 output.libraryTarget 选项,查看您有哪些选项可以在不同的模块系统中公开库。然后在节点和客户端代码中导入共享库。
浏览器错误的关键在于:module.exports 似乎为空。果然,您正在为其设置值,但尚未初始化。如果您这样做:
module.exports = {
proxyExpressCalls: proxyExpressCalls,
devServerProxyConfig: devServerProxyConfig,
targetApi: targetApi
};
(或者先简单地设置 module.exports = {}),这应该可以解决问题。控制台警告可能是代码的副作用,即使在无法为空变量设置值后,该代码仍会继续运行。