Bla*_*wis 2 javascript mysql ejs node.js express
我正在循环遍历 MySQL 表中的记录,将它们显示在 EJS 文件中,然后单击其中一个,路由到页面以编辑记录。但是,我无法将单个对象传递回我的routes.js 文件以将其路由到编辑页面。我循环浏览所有记录并打印它们没有任何问题,所以我知道数据就在那里。这是 EJS 文件的一部分,我在其中输出所有记录以供用户选择:
<body>
<div class="container">
<div class="col-sm-6 col-sm-offset-3">
<h1><span class="fa fa-chess"></span> View Roommate Agreements</h1><br>
<p align="center">Click on a Roommate Agreement below to view the full response and edit if necessary.</p><br>
<% for (var i=0; i < Agreements.length; i++) { %>
<a href="/editAgreement" style="text-decoration: none; color: #333333">
<div class="well" align="center">
<h3>Roommate Agreement for Room #<%= Agreements[i].roomNumber%></h3>
<p><%= Agreements[i].roommate1%></p>
<p><%= Agreements[i].roommate2%></p>
<% var Agreement = Agreements[i]%> //THIS is where I'm trying to declare the object
</div>
</a>
<% } %>
<hr>
<p align="center">
<a href="/agreement" class="btn btn-default btn-sm"><span class="fa fa-arrow-circle-left"></span> Back</a>
<a href="/logout" class="btn btn-default btn-sm"><span class="fa fa-sign-out-alt"></span> Logout</a>
</p>
</div>
</div>
</body>
Run Code Online (Sandbox Code Playgroud)
这里是 Get 函数将对象路由到编辑页面。您可以看到我试图将对象记录到控制台的位置,以确保我获得正确的信息,但它当前打印为“未定义”。
app.get('/editAgreement', isLoggedIn, function(req, res) {
res.render('editAgreement.ejs', {
Employee: req.user
})
console.log(req.body.Agreement);
})
Run Code Online (Sandbox Code Playgroud)
我不确定问题是否在于我如何在 EJS 中声明对象变量,或者如何在 Get 函数中使用它,因为我是 Javascript 新手。任何提示或帮助将不胜感激,谢谢!:)
要将变量传递到另一个页面,GET您必须将它们传递到 中url,这样您将暴露您的数据,如果您有大量信息要传递,那么这不安全并且需要大量工作,您应该仅将协议传递id给路线get,获取协议,然后渲染视图,例如:
<% for (var i=0; i < Agreements.length; i++) { %>
<a href="/editAgreement/<%= Agreements[i].id %>" style="text ...
Run Code Online (Sandbox Code Playgroud)
进而 :
app.get('/editAgreement/:id', isLoggedIn, function(req, res) {
let agreementId = req.params.id;
let agreement = // go fetch the agreement from the database like you did before with the list of agreements
res.render('editAgreement.ejs', agreement)
})
Run Code Online (Sandbox Code Playgroud)