Error: ENOENT: no such file or directory in express-handlebars

只谈情不闲聊 提交于 2019-12-11 14:53:18

问题


I am using express-handlebars to load dynamic content in NodeJS

inside app.js

const express = require("express");
const bodyParser = require("body-parser");
const path = require("path");
const pp = require("./util/path.js");
const adminRoutes = require("./routes/admin");
const shopRoutes = require("./routes/shop");
const expressHbs = require("express-handlebars");
const app = express();

app.engine("hbs",expressHbs());
app.set("view engine", "hbs");
app.set("views", "views");

app.use(bodyParser.urlencoded({ extended: false }));
app.use(express.static(path.join(__dirname, "public")));

app.use("/admin", adminRoutes.routes);
app.use(shopRoutes);

app.use((req, res, next) => {
  res.status(404).render("404", { pageTitle: "Page Not Found" });
});
app.listen(3001, "localhost", () => console.log("Listening on 3001 PORT"));

When expressHbs() function has no param it shows the following error

Error: ENOENT: no such file or directory, open 'C:\dev\nodejs\maximi_course\views\layouts\main.handlebars'

And when i pass an option object to it:

app.engine(
  "hbs",
  expressHbs({
    extname: "hbs",
    layoutsDir: path.join(__dirname, "views")
  })
);

It shows:

Error: ENOENT: no such file or directory, open 'C:\dev\nodejs\maximi_course\views\main.hbs'

I've searched for a solution but i got no result , Actually i am following a tutorial and i have done the same as teacher did but i got an error.

Lastly thing that i have tried is adding defaultLayout property and it works and load the default but when i change the url to another page it always load the same page which i set as default

Here is project folder and all its contents


回答1:


Node.js/Expressjs

Q. Error: ENOENT: no such file or directory, open 'S:\globle_express\views\layouts\main.handlebars'

Answer.

enter image description here

Rename your layout folder and do layouts

The folder structure of Expressjs should be like this



回答2:


Actually it's a bit annoying problem with express-handlebars but got it solved as following:

  • I had to create a standalone file which's not one of Routes and assign its name to defaultLayout
  • I had to set the path to views/layouts/
  • I had to to define extname to the extension i had defined
app.engine(
  "hbs",
  expressHbs({
    extname: "hbs",
    defaultLayout: "main-layout",
    layoutsDir: "views/layouts/"
  })
);



回答3:


There is no need of creating a layouts folder with a file within it.create 'views' folder and add the file. For instance 'form.handlebars' then do the following according to your code

    app.get('/' (req,res)=> {
      res.render("contact", {
      layout: false,
      name: req.body.name,
      quote: req.body.quote
      });
    })



回答4:


I had the same problem and fixed it by using the following method:

app.engine( "hbs", expressHbs({ extname: "hbs", defaultLayout: false, layoutsDir: "views/layouts/" }) );



来源:https://stackoverflow.com/questions/56810751/error-enoent-no-such-file-or-directory-in-express-handlebars

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!