gpt4 book ai didi

javascript - 传入表单数据没有给出响应

转载 作者:可可西里 更新时间:2023-11-01 09:56:18 25 4
gpt4 key购买 nike

我正在运行一个基本的 Web 应用程序,它将通过运行 express 的 node.js 中的 mongoose 对 mongoDb 进行简单查询。如果我执行一个简单的 find(),我可以返回整个数据集,但是,当我尝试将表单数据作为变量传递以查找特定餐厅时,即 find({restaurantname: Arbys}),我无法获得回复。我正在使用 Handlebars 将变量传递回客户端。这似乎是一个路由问题,但我可能误解了如何处理 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() 的 handlebars 脚本

<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 ...

试着改变你的路线“/查询数据详细信息”到“/查询数据详细信息/:餐厅名称”然后你可以得到 RestaurantNamevar RestaurantName = req.query['RestaurantName'];

关于javascript - 传入表单数据没有给出响应,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37842246/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com