我的脚本agents.js
如下
var express = require('express');
var router = express.Router();
var app = express(); // is it wise to call express like this twice?
router.get('/', function(req, res, next) {
var query = "role=agent";
get('employees').then(function(data) {
res.render("agents", {
rows: result,
user: req.user
});
}, function(error) {
res.send(JSON.stringify(error));
});
});
/// how can I expose this function to the application properly?
app.locals.add2Users = function(item) {
console.log("ADDING SOMEONE");
api.create(item, 'employees').then(function(data) {
console.log("Nice");
}, function(error) {
console.log("Error");
});
};
module.exports = router;
还有一个简单的模板agents.ejs
<% for(var i=0; i < rows.length; i++) { %>
<tr>
<td>
<%= rows[i].name %>
</td>
<td>
<%= rows[i].email %>
</td>
<td>
<% if (rows[i].toAdd) { %>
<button type="button" class="btn btn-info btn-outline btn-circle btn-lg m-r-5" onClick="add2Users(rows[i])">
<i class="ti-magnet"></i>
</button>
<% } %>
</td>
</tr>
<% } %>
目标是通过单击add2Users
函数,在单击模板上的按钮时在某个后端数据库上创建用户。我读到您可以通过将EJS模板添加到app.locals
来公开其功能,但是出现错误add2Users is not defined
。我在做什么错?在不违反最佳实践的情况下,在EJS模板上公开脚本功能的最佳方法是什么?
答案 0 :(得分:0)
我没有使用app.locals
,而是创建了一个端点/addUser/{param}
,并在单击按钮时从客户端调用了端点。