簡體   English   中英

使用node從mongodb集合中獲取特定數據

[英]Fetching specific data from mongodb collections using node

他,我需要我的節點和MongoDB應用程序的幫助。

所以我有一個MongoDB數據庫,並使用node.js和express.js來獲取數據。 我可以使用應用程序很好地獲取數據,甚至可以將其發送到瀏覽器。 但我想渲染一個模板(如下所示)。

  <!DOCTYPE html>
<html>
  <head>
    <title>{{ title }}</title>
    <link rel='stylesheet' href='/stylesheets/style.css' />
  </head>
  <body>
    <h1>{{ title }}</h1>
    <p>Hello my name is {{ name }}, and my email is {{ email }}</p>
  </body>
</html>

有了這個模型

var mongoose = require('mongoose');
var Schema = mongoose.Schema;

var usersSchema = new Schema({
  name: String,
  email: String
});

mongoose.model('emaildata', usersSchema);

但是當我嘗試使用此腳本執行此操作時

var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var mongoose = require('mongoose');
var fs = require('fs');
var routes = require('./routes/index');
var users = require('./routes/users');
var app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'hjs');

// 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(cookieParser());
app.use(require('less-middleware')(path.join(__dirname, 'public')));
app.use(express.static(path.join(__dirname, 'public')));
app.use('/', routes);
app.use('/users', users);

// MongoDb Server
mongoose.connect('mongodb://127.0.0.1/emailApp');

// Load all files in models folder. Importing models and schemas
fs.readdirSync(__dirname + '/models').forEach(function(filename) {
  if (~filename.indexOf('.js')) require(__dirname + '/models/' + filename)
});

app.get('/data', function(req, res) {
  mongoose.model('emaildata').find(function(err, emaildata) {
    res.send(emaildata)
    // res.render('email', { title: 'Emails', email: emaildata.email, name: emaildata.name });
  });
});




// 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 handlers

// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
  app.use(function(err, req, res, next) {
    res.status(err.status || 500);
    res.render('error', {
      message: err.message,
      error: err
    });
  });
}

// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
  res.status(err.status || 500);
  res.render('error', {
    message: err.message,
    error: {}
  });
});


module.exports = app;

它不會渲染任何東西。 我認為問題是1.我沒有使用正確的語法來標識對象中的特定數據,例如名稱或電子郵件。 我嘗試通過app.get('/ data'......在腳本的一半位置執行此操作。2.我沒有正確導入對象,因此當我嘗試使用數據來呈現模板時,沒什么。

謝謝一群!

首先, res.send將不使用您的模板文件。

我假設您的模板文件的名稱為“ email”,因此請使用res.render('email', {information : emaildata}) ,在您的模板文件中,請使用{{information.name}}和{{information.email}}渲染它們。(我沒有使用過hjs,因此可能存在一些語法錯誤。)

首先,

導入模態模式

var mydataSchema = require('.<directory>/<yourmodalname>');

然后,如果您的數據庫中已經有一些數據,則可以通過將其更新為模態來獲取數據

var mongoose = require('mongoose');
var Schema = mongoose.Schema;

var usersSchema = new Schema({
  name: String,
  email: String
}, {collection : '<tableName>' });

mongoose.model('emaildata', usersSchema);

然后獲取所有數據:

首先聲明路由器

var router = express.Router();  

獲取數據

router.route('/userData')
 .get(function(req, res) {
        mydataSchema.find(function(err, mydataSchema ) {
            if (err)
                res.send(err);

            res.json(mydataSchema );
        });
    });

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM