zoukankan      html  css  js  c++  java
  • Mongoose 预定义模式修饰符 Getters 与 Setters 自定义修饰符

    mongoose 预定义模式修饰符

    mongoose 提供的预定义模式修饰符,可以对我们增加的数据进行一些格式化,主要有:lowercase、uppercase 、trim,这里不一一演示,对trim做一个示列,其他的使用方式都是一样的

    同样我们先定义一个model文件夹和定义db.js模块用于连接数据库

    const mongoose = require('mongoose');
    
    mongoose.connect('mongodb://127.0.0.1:27017/eggcms', { useNewUrlParser: true }, (err) => {
      if(err){
        return console.log(err);
      }
      console.log('数据库连接成功')
    });
    
    module.exports = mongoose

    定义操作users集合的Schema和model,定义Schema的时候,将name字段添加一个修饰符trim,表示当新增数据或者修改数据的时候,name字段会自动去掉前后的空格

    let mongoose = require('./db')
    
    let UserSchema = mongoose.Schema({
      name: {
        type: String,
        trim: true
      },
      age: Number,
      status: {
        type: Number,
        default: 1
      }
    })
    
    // 定义model操作数据库
    let UserModel = mongoose.model('User',UserSchema,'users');
    
    module.exports = UserModel

    最后在app.js中使用users的model进行数据库的增删改查,插入数据的时候故意在name字段中前后加了空格

    let UserModel = require('./model/users')
    
    // 增加数据
    let u = new UserModel({
      name: ' 黄信 ',
      age: 23
    })
    u.save((err) => {
      if (err) {
        console.log(err)
        return
      }
      console.log('增加数据成功')
    
      // 查询users表的数据
      UserModel.find({}, (err, doc) => {
        if (err) {
          console.log(err)
          return
        }
        console.log(doc)
      })
    })

    运行结果可以看到,添加到数据库中的users表中的name字段前后空格就不存在了

    Mongoose Getters 与 Setters 自定义修饰符

    除了 mongoose 内置的修饰符以外,我们还可以通过 set(建议使用) 修饰符在增加数据的 时候对数据进行格式化。也可以通过 get(不建议使用)在实例获取数据的时候对数据进行(不是获取数据库的数据,而是获取model中的数据)

    需求:在以上的实例中,我们在users集合中添加一个字段:个人主页的网址pic,这个pic字段用户可能没有输入http这个前缀,但是我们数据库要求一定要有htpp前缀

    那么这个时候,我们就i需要在定义Schema的时候对用户输入的数据进行处理,如果用户输入的地址没有带http,那么我就给它添加上,如果有就不用添加

    修改users.js这个model模块

    let mongoose = require('./db')
    
    let UserSchema = mongoose.Schema({
      name: {
        type: String,
        trim: true
      },
      age: Number,
      status: {
        type: Number,
        default: 1
      },
      pic: {
        type: String,
        set (parmas) { //parmas可以获取pic字段的值
          if(!parmas){
            return parmas
          }
    
          if(parmas.indexOf('http://') != 0 && parmas.indexOf('https://')!=0){
            parmas = 'http://' + parmas
          }
    
          return parmas // 返回的数据就是pic在数据库中实际保存的值
        }
      }
    })
    
    // 定义model操作数据库
    let UserModel = mongoose.model('User',UserSchema,'users');
    
    module.exports = UserModel

    在app.js中使用users.js这个model添加一个数据,pic字段的值故意不加http://,然后看看效果

    let UserModel = require('./model/users')
    
    // 增加数据
    let u = new UserModel({
      name: ' 刘菊花 ',
      age: 23,
      pic: 'www.baidu.com'
    })
    u.save((err) => {
      if (err) {
        console.log(err)
        return
      }
      console.log('增加数据成功')
    
      // 查询users表的数据
      UserModel.find({}, (err, doc) => {
        if (err) {
          console.log(err)
          return
        }
        console.log(doc)
      })
    })

    get的使用,同样在users的pic字段中加一个get

    let mongoose = require('./db')
    
    let UserSchema = mongoose.Schema({
      name: {
        type: String,
        trim: true
      },
      age: Number,
      status: {
        type: Number,
        default: 1
      },
      pic: {
        type: String,
        set (parmas) { //parmas可以获取pic字段的值
          if(!parmas){
            return parmas
          }
    
          if(parmas.indexOf('http://') != 0 && parmas.indexOf('https://')!=0){
            parmas = 'http://' + parmas
          }
    
          return parmas // 返回的数据就是pic在数据库中实际保存的值
        },
        get(parmas){
          return 'aaaaaaaaa' + parmas
        }
      }
    })
    
    // 定义model操作数据库
    let UserModel = mongoose.model('User',UserSchema,'users');
    
    module.exports = UserModel

    当我们在app.js中获取数据库数据的时候示没有任何变化的

    let UserModel = require('./model/users')
    
    // 增加数据
    let u = new UserModel({
      name: ' 刘菊花 ',
      age: 23,
      pic: 'www.baidu.com'
    })
    
    // 查询users表的数据
    UserModel.find({}, (err, doc) => {
      if (err) {
        console.log(err)
        return
      }
      console.log(doc)
    })

    那么get到底示干啥用的呢,直接使用增加数据的对象,打印的时候就有了,因为不知道这样到底有啥意义

    let UserModel = require('./model/users')
    
    // 增加数据
    let u = new UserModel({
      name: ' 刘菊花 ',
      age: 23,
      pic: 'www.baidu.com'
    })
    
    // 查询users表的数据
    UserModel.find({}, (err, doc) => {
      if (err) {
        console.log(err)
        return
      }
      console.log(doc)
    })
    
    console.log(u.pic) // aaaaaaaaahttp://www.baidu.com

     

  • 相关阅读:
    CKEditor4x word导入不保存格式的解决方案
    为了希望正式开始开发
    HTTP权威指南-URL与资源
    HTTP权威指南-HTTP概述
    同源策略和跨域访问
    普通Html文件图片上传(Storing Image To DB)
    PostgreSQL时间戳提取的特殊需求
    (转)百度前端规范、腾讯前端规范
    整理一下嵌入式WEB开发中的各种屏蔽(转)
    Excel表格指定列数据转换成文本
  • 原文地址:https://www.cnblogs.com/LO-ME/p/10875431.html
Copyright © 2011-2022 走看看