为什么按钮中的app.locals函数不能在我的EJS模板上运行?

时间:2018-06-24 17:13:44

标签: javascript node.js express ejs

我的脚本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模板上公开脚本功能的最佳方法是什么?

1 个答案:

答案 0 :(得分:0)

我没有使用app.locals,而是创建了一个端点/addUser/{param},并在单击按钮时从客户端调用了端点。