javascript - res.render 抛出错误 Node.JS

标签 javascript css node.js ejs

我一直在尝试创建这个博客,当涉及到呈现页面时,它抛出“Res.Render 不是函数...”

    let express = require("express"),
    app = express(),
    bodyParser = require("body-parser"),
    methodOV = require("method-override"),
    mongoose = require("mongoose"),
    passport = require("passport"),
    pL = require("passport-local"),
    pLM = require("passport-local-mongoose"),
    User = require("./user.js");

mongoose.connect("mongodb://localhost/max");

let maxBlog = new mongoose.Schema({
    title: String,
    author: String,
    content: String
});

let Blog = mongoose.model('Blog', maxBlog);

app.use(express.static("public"));

app.use(bodyParser.urlencoded({ extended: false }))

app.use(bodyParser.json());

app.use(methodOV("_method"));

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

//AUTH

app.use(passport.initialize());
app.use(passport.session());

passport.use(new pL(User.authenticate()));
passport.serializeUser(User.serializeUser());
passport.deserializeUser(User.deserializeUser());

app.post("/register", (req, res) =>{
    User.register(new User({username: req.body.username}), req.body.password, function(err, user){
        if(err){
            console.log(err);
            return res.render('register');
        }
        passport.authenticate("local")(req, res, function(){
           res.redirect("/secret");
        });
    });
});

// LOGIN ROUTES
app.get("/login", (req, res) =>{
   res.render("login"); 
});
//login logic
app.post("/login", passport.authenticate("local", {
    successRedirect: "/secret",
    failureRedirect: "/login"
}) ,(req, res) =>{
});

app.get("/logout", (req, res) => {
    req.logout();
    res.redirect("/");
});


const isLoggedIn = (req, res, next) =>{
    if(req.isAuthenticated()){
        return next();
    } else {
      res.redirect("/login");
    }
};

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

app.get("/", (req,res) => {
    res.redirect("/home");
});

app.get("/home", (req,res) => {
    res.render("index");
});

app.get("/blog", (req,res) => {
    Blog.find({},(err,res) => {
        if (err){
            res.send("An unexpected error occured. Please try again later.");
        } else {
            res.render("blog",{blogs:res});
        }
    });
});

app.post("/blog",isLoggedIn,(req,res) => {
    Blog.create({
        title: req.body.t,
        author: req.body.a,
        content: req.body.c
    }), (err,create) => {
        if (err){
            res.send("There was an error. Try again later.");
        } else {
            res.render("blogs");
        }
    };
});

app.get("/blog:id",(req,res) => {
    Blog.findById(req.params.id,(err,find) => {
        if (err){
            res.send("An error occured. Please try again later.");
        } else {
            res.render("show",{blog:find});
        }
    });
});

app.put("/blogs:id",isLoggedIn,(req,res) => {
    Blog.findByIdAndUpdate(req.params.id,({
        content: req.body.c,
        author: req.body.a
    }),(err,update) => {
        if (err){
            res.send("An error occured. Please try again later.");
        } else {
            res.redirect("/blogs"+req.params.id);
        }
    });
});

app.listen(8080);

求助!谢谢你,本 这一直困扰着我很长时间。这很奇怪,所有解决方案都没有奏效。不幸的是,我尝试了很多东西,但没有任何效果。非常感谢。

最佳答案

这是由于参数定义问题。

您可以尝试将第一个函数参数的名称更改为response:

app.get("/blog", (req,response) => {
    Blog.find({},(err,res) => {
        if (err){
            response.send("An unexpected error occured. Please try again later.");
        } else {
            response.render("blog",{blogs:res});
        }
    });
});

关于javascript - res.render 抛出错误 Node.JS,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46626461/

相关文章:

javascript - 无法在 Node js 教程中提交表单

javascript - 当用户单击刷新按钮时从 mysql 表中删除数据

html - 按钮 CSS 文本的对齐问题

javascript - css 属性 "display"无法正常工作

javascript - 使用node.js解析json时遇到问题

javascript - SonarQube 预览模式失败并出现 500 错误

javascript - 解压缩缩小的javascript的合法性

javascript - 在 ASP.net C# 中使用 Google 热图 API 服务

javascript - ReactJS如何将子组件值传递给父组件

html - 显示 :table & display:table-cell not working in IE9