【问题标题】:How can I render .ejs file from node.js controller?如何从 node.js 控制器渲染 .ejs 文件?
【发布时间】:2017-09-20 11:30:52
【问题描述】:

我有以下文件夹结构:

  • bin
  • 控制器
  • 型号
  • node_modules
  • 公开
  • 路线
  • 观看次数
  • app.js
  • package.json
  • 由于我是 node.js 和 express.js 的新手,我想知道如何从控制器文件中渲染 .ejs 文件。目前,我的代码如下所示:

    //控制器/login.js

    module.exports = {
        getLoginPage: function (req, res) {
            res.render('login-form');
        }
    };
    

    //routes/login.js

    var login = require('../controllers/login');
    module.exports = function(app){    
        app.get('/', login.getLoginPage);
    };
    

    //app.js

    var express = require('express');
    var http = require('http');
    var path = require('path');
    var favicon = require('serve-favicon');
    var logger = require('morgan');
    var cookieParser = require('cookie-parser');
    var bodyParser = require('body-parser'); //parses information from POST
    var stylus = require('stylus');
    var validator = require('express-validator');
    var session = require('express-session');
    
    var app = express();
    
    require('./routes/login')(app);
    
    // view engine setup
    app.set('views', path.join(__dirname, 'views'));
    app.set('view engine', 'ejs');
    
    // uncomment after placing your favicon in /public
    //app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
    app.use(logger('dev'));
    app.use(bodyParser.json());
    app.use(bodyParser.urlencoded({ extended: false }));
    app.use(validator());
    app.use(cookieParser());
    app.use(stylus.middleware(path.join(__dirname, 'public')));
    app.use(express.static(path.join(__dirname, 'public')));
    app.use(session({secret: 'max', saveUninitialized: false, resave: false}));
    
    // catch 404 and forward to error handler
    app.use(function(req, res, next) {
      var err = new Error('Not Found');
      err.status = 404;
      next(err);
    });
    
    // error handler
    app.use(function(err, req, res, next) {
      // set locals, only providing error in development
      res.locals.message = err.message;
      res.locals.error = req.app.get('env') === 'development' ? err : {};
    
      // render the error page
      res.status(err.status || 500);
      res.render('error');
    });
    
    module.exports = app;
    

    在我的控制器中,如果我编写 res.send("Hello");,它会打印,但我希望整个 .ejs 文件显示在我的浏览器上。这怎么可能?

    另外,如果我从路由中渲染 .ejs,它会正确显示,但不会从控制器中显示。

    //错误

    Error: Failed to lookup view "error" in views directory "C:\node\folder-name\views"
        at EventEmitter.render (C:\node\folder-name\node_modules\express\lib\application.js:580:17)
        at ServerResponse.render (C:\node\folder-name\node_modules\express\lib\response.js:971:7)
        at C:\node\folder-name\app.js:60:7
        at Layer.handle_error (C:\node\folder-name\node_modules\express\lib\router\layer.js:71:5)
        at trim_prefix (C:\node\folder-name\node_modules\express\lib\router\index.js:315:13)
        at C:\node\folder-name\node_modules\express\lib\router\index.js:284:7
        at Function.process_params (C:\node\folder-name\node_modules\express\lib\router\index.js:335:12)
        at next (C:\node\folder-name\node_modules\express\lib\router\index.js:275:10)
        at Layer.handle_error (C:\node\folder-name\node_modules\express\lib\router\layer.js:67:12)
        at trim_prefix (C:\node\folder-name\node_modules\express\lib\router\index.js:315:13)
    

    谢谢

    【问题讨论】:

    • @DevAymen 该解决方案对我不起作用。

    标签: javascript jquery node.js express ejs


    【解决方案1】:

    将您的视图路径更改为:-

    app.set('views',path.join(__dirname+'/views/'));
    

    然后在控制器中你可以简单地使用

    //assuming hello.ejs is in your view folder
    response.render('hello.ejs');
    

    如果视图文件夹中有文件夹,则使用

    response.render('error/404.ejs');
    

    【讨论】:

      【解决方案2】:

      首先需要设置视图的渲染引擎:

      app.set('view engine','ejs');
      

      【讨论】:

        【解决方案3】:

        您需要将视图引擎设置为 ejs :

        app.set('view engine', 'ejs')
        

        Docs

        【讨论】:

        • 你能显示更多代码和信息吗,比如直接在views文件夹或子文件夹中的视图。错误信息是什么?
        • 请检查更新后的问题。是的,.ejs 文件在 views 文件夹下。
        • 据我所见。应用程序到达您在 app.js 中设置的错误处理程序,当它到达 res.render('error') 时,它找不到错误视图。这很奇怪,因为app.use 在路由处理程序之后,并且逻辑上不应该到达中间件,因为您没有在路由中调用next() ....尝试同时删除 404 转发到错误处理程序和错误处理程序,并查看是否呈现视图
        • 删除这些代码后,它给了我这个错误:“TypeError: Cannot read property 'errors' of undefined”。
        • 该错误发生在哪里。我假设错误消息指向错误行?
        【解决方案4】:

        尝试以下方法:

        var path = require('path');
        res.render(path.resolve('./views/error'))
        

        【讨论】:

          猜你喜欢
          • 2020-05-29
          • 2018-01-12
          • 2018-12-23
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2019-12-05
          • 1970-01-01
          相关资源
          最近更新 更多