У меня проблема с Res.json в приведенном ниже коде:
/* GET all users */
app.get('/users', function (res) {
db.users.findAll()
.then(users => {
res.json(users);
});
});
Когда-то это работало довольно хорошо, но теперь это не так. У меня есть эта ошибка для всех res.json только с app.get, который использует findAll ...
Unhandled rejection TypeError: res.json is not a function
Я не понимаю, почему res.json работает во всех моих функциях, но не с findAll: /





Прототип / подпись обратного вызова неверны, должно быть так:
app.get('/users', function(req, res) { ... })
В вашем примере вы пытаетесь вызвать req.json, которого не существует.
Надеюсь, это поможет,
С наилучшими пожеланиями
РЕДАКТИРОВАТЬ
Если вам не нужен req, вы не можете просто удалить его, потому что Express ожидает, что он будет там, поэтому он вызовет вашу анонимную функцию с 3 обычными параметрами: req, res и next.
Express не может догадаться, что вы хотите, чтобы res был первым параметром вашей функции.
Но если вы хотите, чтобы другие люди знали, что вы не будете использовать эту переменную, вы можете сделать что-то вроде этого:
app.get('/users', function(_, res) { ... })
ИЛИ ЖЕ
app.get('/users', function(_req, res) { ... })
Допустимая практика - ставить перед бесполезными переменными знак подчеркивания, если он не имеет другого значения. Не делайте этого, если вы используете underscore.js или Lodash
О, я вижу ! Я не думал, что будет важно соблюдать требования, даже если я им не пользуюсь! Спасибо :)