mongoose验证相关

一、mongoose 常见验证规则

1.required:true 必传字段
2.minlength: 字符串最小长度
3.maxlength:   字符串最大长度
4.min:  数值类型最小值
5.max:  数值类型最大值
6.enum:['html','css','javascript','node.js'] 规定可供选择输入的值列表
7.trim: true 去除字符串两边的空格
8.validate: 自定义验证器
9.defaule


二、实例代码

const mongoose = require('mongoose');
mongoose.connect('mongodb://localhost:/playground',{ useNewUrlParser: true ,useUnifiedTopology: true})
    .then(()=>console.log('数据库连接成功'))
    .catch(err=>console.log(err,'数据库连接失败'))

const postSchema = new mongoose.Schema({
    title:{
        type:String,
        required:[true,'标题为必填项'], //可用数组形式自定义返回错误提示
        minlength:[2,'标题长度过短'],
        maxlength:4, //默认样式不用数组形式表示
        trim:true   //去除首尾空格
    },
    age:{
        type:Number,
        min:2,
        max:100
    },
    publishDate:{
        type:Date,
        default:Date.now
    },
    category:{
        type:String,
        // enum:['javascript','html','node.js'] //枚举出当前可供选择输入的值列表
        enum:{
            values:['javascript','html','node.js'],
            message:'请在指定分类中输入正确值'
        }
    },
    author:{
        type:String,
        validate:{  //自定义验证规则
            validator:v=>{
                //返回布尔值
                //true 验证成功
                //false 验证失败
                //v 要验证的值
              return   v && v.length > 4
            },
            message:'作者姓名长度格式不符合' //自定义错误返回提示
        }

    }
})

const  Post = mongoose.model('Post',postSchema);
Post.create({title: 'eee',age:18,publishDate: '2020-2-2 18:00:00',category: 'javas',author: 'ss'})
    .then(result=>console.log(result))
    .catch(error =>{
        const err =error.errors; //获取错误对象
        for(let att in err){
            console.log(err[att]['message'])//控制台获取错误信息
        }
    })
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值