私は、一般的にそのようなことにヘルパー機能を使用します。私が使っているものより少し一般的になるようにこれを嘲笑しました。この男はすべての "デフォルト"バリデーター(必須、最小、最大など)をとり、メッセージを少しきれいにします(messages
オブジェクトに従います)。検証。
function errorHelper(err, cb) {
//If it isn't a mongoose-validation error, just throw it.
if (err.name !== 'ValidationError') return cb(err);
var messages = {
'required': "%s is required.",
'min': "%s below minimum.",
'max': "%s above maximum.",
'enum': "%s not an allowed value."
};
//A validationerror can contain more than one error.
var errors = [];
//Loop over the errors object of the Validation Error
Object.keys(err.errors).forEach(function (field) {
var eObj = err.errors[field];
//If we don't have a message for `type`, just push the error through
if (!messages.hasOwnProperty(eObj.type)) errors.push(eObj.type);
//Otherwise, use util.format to format the message, and passing the path
else errors.push(require('util').format(messages[eObj.type], eObj.path));
});
return cb(errors);
}
そして、それは、この(ルータの一例を表す)のように使用することができます後
{ message: 'Validation failed',
name: 'ValidationError',
errors:
{ username:
{ message: 'Validator "required" failed for path username',
name: 'ValidatorError',
path: 'username',
type: 'required' },
state:
{ message: 'Validator "enum" failed for path state',
name: 'ValidatorError',
path: 'state',
type: 'enum' },
email:
{ message: 'Validator "custom validator here" failed for path email',
name: 'ValidatorError',
path: 'email',
type: 'custom validator here' },
age:
{ message: 'Validator "min" failed for path age',
name: 'ValidatorError',
path: 'age',
type: 'min' } } }
::前
function (req, res, next) {
//generate `user` here
user.save(function (err) {
//If we have an error, call the helper, return, and pass it `next`
//to pass the "user-friendly" errors to
if (err) return errorHelper(err, next);
}
}
[ 'username is required.',
'state not an allowed value.',
'custom validator here',
'age below minimum.' ]
編集:スナップ、ちょうどこれがCoffeeScriptの質問だったことに気づいた。 CoffeeScriptの人ではないので、CSでこれを書き直したいとは思っていません。あなたはいつもあなたのCSにjs
ファイルとしてそれを要求することができますか?
表現-バリうまく機能もあります。 – chovy