声明模式类型:
var schema1 = new Schema({
test: String // 声明`test`类型为字符串
});
var schema2 = new Schema({
test: { type: Number } // 声明`test`类型为字符串
});
类型包含:String、Number、Objectid、Bollean、function、data、Mixed、Array
schema常用字段解析
var schema3 = new Schema({
test: {
type: String,
lowercase: true, // 总是将test的值转化为小写
uppercase: true, // 总是将test的值转化为大写
required:true, //设定是否必填
default:'star', //设定默认值
index:true, //设定索引值
unique:true, //索引值唯一
sparse:true, //是否启用稀疏索引
match:RegExp, //判断是否通过正则验证
enum:Array, //判断test值是否包含于enmu对应的数组中
min:Number, //判断对应值是否大于等于给定值
max:Number, //判断对应值是否小于等于给定值
trim:true //去除数据前后的空格
capped:1024 //限定大小最大为1024字节
validate:function,为此属性添加一个验证器函数,如demo1所示
get:function,//为这个属性定义一个定制的getter Object.defineProperty()。如demo2所示
set:function,//定义此属性的自定义设置Object.defineProperty()。如demo2所示
}
});
demo1: validate
/初始化schema对象
var EmailTemplateSchema = new Schema({
fileName: {
type: String,
trim: true,
default: '',
validate: [validateLocalStrategyProperty, 'Please fill in your first name']
}
});
//初始化对象时添加验证,验证传入的值是否合法
var validateLocalStrategyProperty = function (property) {
return (!this.updated || property.length);
};
demo2: get/set
//将传入的值四舍五入后存储
var numberSchema = new Schema({
integerOnly: {
type: Number,
get: v => Math.round(v),
set: v => Math.round(v),
require:true
}
});