javascript - 在javascript中将表单数据解析为对象(无法读取未定义的属性 'name')

标签 javascript node.js mongodb express pug

我正在关注 here 上的 mongodb 教程。这只是一个提交表单,其中将一个人的姓名、年龄和国籍添加到数据库中。但我收到以下错误:

TypeError: Cannot read property 'name' of undefined

at /home/me/Desktop/nodejs/mongoose-example/index.js:24:18

所以看起来它不想将 req.body 解析为 personInfo。程序如下:

const express = require('express');
const app = express();

app.set('view engine', 'pug');
app.set('views', './views');

var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/my_db');

var personSchema = mongoose.Schema({
        name: String,
        age: Number,
        nationality: String
});
var Person = mongoose.model("Person", personSchema);

app.get('/person', function(req, res){
        res.render('person');
});

app.post('/person', function(req, res){
        var personInfo = req.body; // Get the parsed information

        if (!personInfo.name || !personinfo.age || !personInfo.nationality){
                res.render('show_message', {
                        message: "Sorry, you provided wrong info", type: "error"});
        } else {
                var newPerson = new Person({
                        name: personInfo.name,
                        age: personInfo.age,
                        nationality: personInfo.nationality
                });

                newPerson.save(function(err, Person){
                        if(err)
                                res.render('show_message', {message: "Database error", type: "error"});
                        else
                                res.render('show_message', {
                                        message: "New person added", type: "success", person: personInfo});
                });
        }
});

app.listen(3000);

这是 person.pug:

html
head
   title Person
   body
       form(action = "/person", method = "POST")
          div
             label(for = "name") Name:
             input(name = "name")
          br
          div
             label(for = "age") Age:
             input(name = "age")
          br
          div
             label(for = "nationality") Nationality:
             input(name = "nationality")
          br
          button(type = "submit") Create new person

最佳答案

这是因为您没有将正文解析为 JSON 格式。要解析它,您必须在获取和发布路由之前包含一个中间件。您可以像这样解析正文:-

app.use(express.json({limit: '5mb'})); //for parsing json
app.use(express.urlencoded({ extended: true,limit: '5mb' })); //for parsing x-ww-form- 
urlencoded request bodies

希望这有帮助!

关于javascript - 在javascript中将表单数据解析为对象(无法读取未定义的属性 'name'),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58707094/

相关文章:

javascript - 如何删除重复结果并合并在 mySQL 查询中具有相似属性的对象?

javascript - 使用 _id mongodb 数组删除多行

javascript - 禁用点击并重置它(Javascript Vanilla)

javascript - 如何防止 *ngFor 更新 Angular 4 中的 DOM?

javascript - 如何在 JavaScript 中创建对象数组?

javascript - 如何通过createElement获取Firefox的垂直范围元素( slider )?

javascript - 在 Node 服务器上使用 mongoose 将分层 Node 从 json 文件保存到 mongodb 中

node.js - 如何将 MongoDB findOne() 与 mongoose 一起使用

javascript - Mongoose 使用 $regex 搜索所有字段

mongodb - 没有重复的 Mongoose 帖子