【发布时间】:2017-04-18 23:52:46
【问题描述】:
当我在项目中包含 Express 时,我在尝试使用 webpack 构建时总是会遇到这些错误。
webpack.config.dev.js
var path = require("path")
module.exports = {
entry: {
"server": "./server/server.ts"
},
output: {
path: path.resolve(__dirname, "dist"),
filename: "bundle.js",
publicPath: "/public/"
},
module: {
loaders: [
{
test: /\.ts(x?)$/,
exclude: /node_modules/,
loader: "ts-loader"
}, {
test: /\.js(x?)$/,
exclude: /node_modules/,
loader: "babel-loader"
}, {
test: /\.json$/,
loader: "json-loader"
}, {
test: /\.scss$/,
exclude: /node_modules/,
loaders: ["style-loader", "css-loader", "postcss-loader", "sass-loader"]
}, {
test: /\.css$/,
loader: ["style-loader", "css-loader", "postcss-loader"]
}, {
test: /\.(jpe?g|gif|png|svg)$/i,
loader: 'url-loader?limit=10000'
}
]
}
}
我试过了:
- 正在安装“fs”,但它不起作用
-
在某处读取以更改节点 fs 属性。它消除了错误警告,但我认为这不是一个好的永久解决方案。
module.exports = { node: { fs: "empty" } }时间:2496 毫秒 资产大小块块名称 bundle.js 761 kB 0 [发出] 服务器 bundle.js.map 956 kB 0 [发出] 服务器 + 119 个隐藏模块
./~/express/lib/view.js 中的警告 关键依赖: 78:29-56 依赖的请求是一个表达式 @ ./~/express/lib/view.js 78:29-56 ./~/express/lib/view.js 中的错误
找不到模块:错误:无法解析 /Users/clementoh/Desktop/boilerplate2/node_modules/express/lib 中的模块“fs” @ ./~/express/lib/view.js 18:9-22 ./~/send/index.js 中的错误
找不到模块:错误:无法解析 /Users/clementoh/Desktop/boilerplate2/node_modules/send 中的模块“fs” @ ./~/send/index.js 24:9-22 ./~/etag/index.js 中的错误
找不到模块:错误:无法解析 /Users/clementoh/Desktop/boilerplate2/node_modules/etag 中的模块“fs” @ ./~/etag/index.js 22:12-25 ./~/destroy/index.js 中的错误
找不到模块:错误:无法解析 /Users/clementoh/Desktop/boilerplate2/node_modules/destroy 中的模块“fs” @ ./~/destroy/index.js 14:17-30 ./~/mime/mime.js 中的错误
找不到模块:错误:无法解析 /Users/clementoh/Desktop/boilerplate2/node_modules/mime 中的模块“fs” @ ./~/mime/mime.js 2:9-22
【问题讨论】:
-
您是否尝试将
"target": "node"添加到您的webpack.config.js? -
哦哈哈,这实际上解决了“fs”问题:) 我将如何解决警告? -
Critical dependencies: 78:29-56 the request of a dependency is an expression @ ./~/express/lib/view.js 78:29-56 ERROR in ./~/express/lib/view.js -
我记得通过简单地破坏
node_modules文件夹并再次执行npm install就可以多次摆脱这种事情。 -
target: 'node'只有在使用 webpack 构建服务器端代码时才应添加。如果您使用的是静态反应 SPA,则永远不应使用target: 'node',因为它不会捆绑您的依赖项,并且您的应用程序可能无法正确加载。我想我最终在捆绑包中包含了node_modules,并使用 react-router 来拆分代码并降低初始 SPA 加载时间。
标签: javascript node.js webpack