我正在使用webpack,typescript和ejs编写一个快速Web应用程序。当遇到其中一个应该提供.ejs文件的路由时,我收到以下错误:
Error: Cannot find module "."
at webpackMissingModule (/Users/max/Development/test/express-webpack/dist/server.js:20669:74)
at new View (/Users/max/Development/test/express-webpack/dist/server.js:20669:152)
at EventEmitter.render (/Users/max/Development/test/express-webpack/dist/server.js:18776:12)
at ServerResponse.render (/Users/max/Development/test/express-webpack/dist/server.js:20479:7)
at /Users/max/Development/test/express-webpack/dist/server.js:25508:7
at Layer.handle [as handle_request] (/Users/max/Development/test/express-webpack/dist/server.js:4524:5)
at next (/Users/max/Development/test/express-webpack/dist/server.js:4743:13)
at Route.dispatch (/Users/max/Development/test/express-webpack/dist/server.js:4724:3)
at Layer.handle [as handle_request] (/Users/max/Development/test/express-webpack/dist/server.js:4524:5)
at /Users/max/Development/test/express-webpack/dist/server.js:4054:22
以下是代码:
{
"name": "express-webpack",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "",
"license": "ISC",
"dependencies": {
"awesome-typescript-loader": "^3.0.0-beta.18",
"copy-webpack-plugin": "^4.0.1",
"debug": "^2.6.0",
"ejs": "^2.5.5",
"express": "^4.14.0",
"json-loader": "^0.5.4",
"source-map-loader": "^0.1.6",
"webpack": "^2.2.0-rc.3"
}
}
var CopyWebpackPlugin = require('copy-webpack-plugin');
module.exports = {
entry: __dirname + "/src/index.js",
target: "node",
output: {
filename: "server.js",
path: __dirname + "/dist"
},
// Enable sourcemaps for debugging webpack's output.
devtool: "source-map",
resolve: {
// Add '.ts' and '.tsx' as resolvable extensions.
extensions: [".webpack.js", ".web.js", ".ts", ".tsx", ".js"]
},
module: {
rules: [
// All files with a '.ts' or '.tsx' extension will be handled by 'awesome-typescript-loader'.
{ test: /\.tsx?$/, loader: "awesome-typescript-loader" },
{ test: /\.json$/, loader: 'json-loader' },
// All output '.js' files will have any sourcemaps re-processed by 'source-map-loader'.
{ enforce: "pre", test: /\.js$/, loader: "source-map-loader" }
]
},
plugins: [
new CopyWebpackPlugin([
{ from: 'src/views', to: 'views' }
])
],
node: {
fs: "empty"
}
};
var express = require('express');
var app = express();
app.set("view engine", "ejs");
app.set("views", "./views");
app.get('/', function(req, res, next){
res.render('index'); // <-- error originates here AFAIK
});
app.listen(8000);
hello world
webpack
以构建项目node dist/server.js
http://localhost:8000
知道出了什么问题吗?
答案 0 :(得分:12)
我深入研究了webpack生成的代码,发现似乎webpack的context parse evaluation存在错误。有一个简单的表达式表示用于要求选定的视图引擎,但它无法解决这个问题。
要解决此问题,请在索引中编写
const ejs = require("ejs").__express;
const app = express();
app.set("view engine", "ejs");
app.engine('.ejs', ejs);// <-- this does the trick
但是如果你想要一个明确的解决方案,请在webpack repo上打开一个问题。
答案 1 :(得分:2)
我相信你的问题与你的捆绑文件(dist / server.js)有关 无法访问您的依赖项,快递,模板引擎等。为了 排除你可以配置webpack以避免捆绑依赖项 (由于您的应用程序从服务器/节点端运行):
var CopyWebpackPlugin = require('copy-webpack-plugin');
module.exports = {
entry: __dirname + "/src/index.js",
target: "node",
output: {
filename: "server.js",
path: __dirname + "/dist"a
},
// Enable sourcemaps for debugging webpack's output.
devtool: "source-map",
resolve: {
// Add '.ts' and '.tsx' as resolvable extensions.
extensions: [".webpack.js", ".web.js", ".ts", ".tsx", ".js"]
},
module: {
rules: [
// All files with a '.ts' or '.tsx' extension will be handled by 'awesome-typescript-loader'.
{ test: /\.tsx?$/, loader: "awesome-typescript-loader" },
{ test: /\.json$/, loader: 'json-loader' },
// All output '.js' files will have any sourcemaps re-processed by 'source-map-loader'.
{ enforce: "pre", test: /\.js$/, loader: "source-map-loader" }
]
},
plugins: [
new CopyWebpackPlugin([
{ from: 'src/views', to: 'views' }
])
],
node: {
fs: "empty"
}
};
// Node module dependencies should not be bundled
config.externals = fs.readdirSync("node_modules")
.reduce(function(acc, mod) {
if (mod === ".bin") {
return acc
}
acc[mod] = "commonjs " + mod
return acc
}
您可能还需要使用节点选项config覆盖节点全局配置 要从您的捆绑文件中访问views文件夹,更多详细信息: https://webpack.js.org/configuration/node/#components/sidebar/sidebar.jsx
答案 2 :(得分:1)
加上Cleiton的答案,您现在必须在调用app.engine(string,callback)时具有回调函数
app.set('views', 'src/views');
app.set('view engine', 'ejs');
app.engine('ejs', require('ejs').__express); //<-- this