我正在运行一个基本的Web应用程序,它将通过运行express的node.js中的mongoose对mongoDb进行简单查询。如果我执行简单的find(),则可以返回整个数据集,但是,当我尝试将表单数据作为变量传递以查找特定餐厅时,即find({restaurantname:Arbys}),我无法获取响应。我正在使用把手将变量传递回客户端。似乎这是一个路由问题,但我可能会误会如何处理GET / POST
这是执行查询的js
//external packages
var express = require('express');
var router = express.Router();
var mongoose = require('mongoose');
var csrf = require('csurf');
var passport = require('passport');
//organic packages & models
var restData = require('../models/restaurants');
/* GET Mongo home page. */
router.get('./mongo', function(req,res,next){
res.render('mongo');
});
//Get Data **This works fine**
router.get('/get-data', function(req,res,next){
restData.find()
.then(function(doc){
res.render('mongo/mongo', {items: doc});
})
});
//Goes to query page with form input
router.get('/query-data', function(req,res,next){
res.render('mongo/mongo-query');
});
//Query specific data **This does not work**
router.get('/query-data-details', function(req,res,next){
var RestaurantName = req.query['RestaurantName'];
if (RestaurantName.length == 0) {
res.render('mongo/mongo', {items: "No Docs Found"});
} else {
restData.find({name: RestaurantName})
.then(function (doc) {
res.render('mongo/mongo', {items: doc});
console.log(RestaurantName);
});
}
});
这是车把脚本,它成功返回没有查询参数的find()
<div class="container float-left">
<a href="/mongo/get-data" <button type="button" class="btn btn-primary">Load All Data</button></a>
<a href="/mongo/query-data" <button type="button" class="btn btn-primary">Query Specific Data</button></a>
<h2>Data</h2>
<p>Retrieves restauraunt data by Name, Cuisine, Borough and Address
<div class="table-responsive">
<table class="table table-bordered">
<thead>
<tr>
<th>Name</th>
<th>Cuisine</th>
<th>Borough</th>
<th>Address</th>
</tr>
</thead>
<tbody>
{{# each items }}
<tr>
<td>{{this.name}}</td>
<td>{{this.cuisine}}</td>
<td>{{this.borough}}</td>
<td>{{this.address}}</td>
</tr>
{{/each}}
</tbody>
</table>
</div>
</div>
</body>
最后,这就是到目前为止我要查询特定餐厅名称的内容
<form method="get" action="/query-data-details">
<input type=text name="RestaurantName">
<input type="submit">
</form>
</body>
app.js部分
var routeshome = require('./routes/index');
var routesmongo = require('./routes/mongo');
var users = require('./routes/users');
var app = express();
require('./config/passport');
// view engine setup
app.engine('hbs', hbs({extname: 'hbs', defaultLayout: 'layout', layousDir: __dirname + '/views/layouts' }));
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'hbs');
// 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(expressValidator());
app.use(cookieParser());
app.use(expressSession({secret: 'b5Frapradra5wen', saveUninitialized: false, resave: false}));
app.use(flash());
app.use(passport.initialize());
app.use(passport.session());
app.use(express.static(path.join(__dirname, 'public')));
app.use('/', routeshome);
app.use('/users', users);
app.use('/mongo', routesmongo);
最佳答案
看来您是在url参数中发送RestaurantName ...
尝试更改您的路线
“/ query-data-details”到
“/ query-data-details /:RestaurantName”
那么你可以得到RestaurantName
var RestaurantName = req.query ['RestaurantName'];