EJS 导入(使用快递)不渲染部分



我正在尝试将我的部分呈现为视图,但不断收到错误

Error: Could not find the include file "('partials/header')"

我的文件结构是这样的:

-MAIN FOLDER
 -controllers
   -userController
   -staticPagesController
   -postsController
 -models
    posts
    users
 -public
    stylesheets
 -views
    user
      all user ejs files
    post
      all post ejs files
    site
      all staticpage ejs files
    partials
      all partials
 -index.js

我尝试将我的 partss 文件夹添加到每个视图子文件夹中,但它没有任何帮助。我还认为也许我的控制器没有正确看到路径,并将 ejs = require( ejs ( 添加到每个控制器路径,但它也没有修复它。

我的观点如下所示:

<%- include ('partials/header') %>
<h1>Homepage</h1>

我的索引.js看起来像这样:

//Application global constants
const express    = require(`express`);
const mongoose   = require(`mongoose`);
const bodyParser = require(`body-parser`);
const ejs        = require('ejs');
const _          = require(`lodash`);      
//Initiate Express
const app = express();
app.use(express.static(`public`));
//Initiate EJS engine
app.set(`view engine`, `ejs`);
app.engine('html', require('ejs').renderFile);
//Initiate body parser
app.use(bodyParser.urlencoded({extended: true}));
//Set express static files

//ROUTING
staticPages = require(`./controllers/staticPageController`);
postPages = require(`./controllers/postController`);
userPages = require(`./controllers/userController`);

请您尝试添加以下代码:

var express = require('express');
var app = express();
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');

还包括标题,例如(特别删除空格(:

<%- include('partials/header') %>

添加"views"文件夹声明

app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');

最新更新