Привет, я пытаюсь использовать макеты Express EJS в своем приложении. При попытке app.use(expressEjsLayouts)
выдает ошибку. Без него приложение прекрасно работает, но я бы хотел использовать ExpressEjs-Layouts для своих шаблонов. Пожалуйста, будьте добры, я новичок в кодировании :) Я уже просмотрел много сообщений, но не нашел ответа. Вот мой сервер.js
if (process.env.NODE_ENV !== 'production') {
require('dotenv').config()
}
const express = require('express')
const app = express()
const passport = require('passport')
const flash = require('express-flash')
const session = require('express-session')
const methodOverride = require('method-override')
const indexRouter = require("./routes/index")
app.use(express.urlencoded({ extended: false }))
app.use(flash())
app.use(session({
secret: process.env.SESSION_SECRET,
resave: false,
saveUninitialized: false
}))
app.use(passport.initialize())
app.use(passport.session())
const initializePassport = require('./passport-config')
const expressEjsLayouts = require('express-ejs-layouts')
initializePassport(
passport,
email => indexRouter.users.find(user => user.email === email),
id => indexRouter.users.find(user => user.id === id)
)
// Set Template Engine
app.use(expressEjsLayouts) // THIS SEEMS TO BE WHAT MAKES IT CRASH
app.set("layout", "layouts/layout")
app.set('view-engine', 'ejs')
app.set("views", __dirname + "/views")
// Static Files
app.use(express.static("public"))
app.use("/", indexRouter.router)
app.use(methodOverride('_method'))
app.listen(process.env.PORT || 3000)
Это ошибка:
Error: No default engine was specified and no extension was provided.
at new View (C:\Users\admin\Documents\Alles mit JS\gefahrengueterproject\node_modules\express\lib\view.js:61:11)
at Function.render (C:\Users\admin\Documents\Alles mit JS\gefahrengueterproject\node_modules\express\lib\application.js:570:12)
at ServerResponse.render (C:\Users\admin\Documents\Alles mit JS\gefahrengueterproject\node_modules\express\lib\response.js:1012:7)
at ServerResponse.res.render [as __render] (C:\Users\admin\Documents\Alles mit JS\gefahrengueterproject\node_modules\express-flash\lib\express-flash.js:29:16)
at C:\Users\admin\Documents\Alles mit JS\gefahrengueterproject\node_modules\express-ejs-layouts\lib\express-layouts.js:113:20
at tryHandleCache (C:\Users\admin\Documents\Alles mit JS\gefahrengueterproject\node_modules\ejs\lib\ejs.js:260:5)
at View.exports.renderFile [as engine] (C:\Users\admin\Documents\Alles mit JS\gefahrengueterproject\node_modules\ejs\lib\ejs.js:485:10)
at View.render (C:\Users\admin\Documents\Alles mit JS\gefahrengueterproject\node_modules\express\lib\view.js:135:8)
at tryRender (C:\Users\admin\Documents\Alles mit JS\gefahrengueterproject\node_modules\express\lib\application.js:640:10)
at Function.render (C:\Users\admin\Documents\Alles mit JS\gefahrengueterproject\node_modules\express\lib\application.js:592:3)
Вам нужно сообщить Express, какой движок просмотра вы используете.
Вы можете сделать это, используя метод app.set()
.
принимает два параметра
1. что вы устанавливаете. в этом случае механизм просмотра
2. тип механизма просмотра, который вы хотите использовать
например app.set('view engine', 'ejs')
;
или app.set('view engine', 'pug')
;
Вот документация https://expressjs.com/ru/guide/using-template-engines.html
Пожалуйста. и не волнуйтесь, это случается со многими людьми, включая меня самого.
Возможно, вам потребуется добавить расширение к имени представления.
Это выдает ошибку в моем случае:
response.render("register", { message: existsMessage });
Но это работает:
response.render("register.ejs", { message: existsMessage });
Несмотря на то, что я определил это в верхней части моего сервера:
app.set("view-engine", "ejs");
Мои представления находятся в каталоге представлений
Привет, Нордин, спасибо за быстрый ответ! Кажется, это была простая орфографическая ошибка! Классика :D Вместо
app.set('view engine', 'ejs')
я использовалapp.set('view-engine', 'ejs')
Большое спасибо!