MongoDB
 sql >> Database >  >> NoSQL >> MongoDB

imposta i valori predefiniti sugli array mongoose nel nodo js

Mongoose ti consente di "separare" le definizioni degli schemi. Sia per il "riutilizzo" generale che per la chiarezza del codice. Quindi un modo migliore per farlo è:

// general imports
var mongoose = require('mongoose'),
    Schema = mongoose.Schema;

// schema for params
var paramSchema = new Schema({
    "name": { "type": String, "default": "something" },
    "value": { "type": String, "default": "something" }
});

// schema for features
var featureSchema = new Schema({
    "name": { "type": String, "default": "something" }
    "params": [paramSchema]
});

var appSchema = new Schema({
    "appFeatures": [featureSchema]
});

// Export something - or whatever you like
module.export.App = mongoose.model( "App", appSchema );

Quindi è "pulito" e "riutilizzabile" se si è disposti a rendere le definizioni di "Schema" parte dei singoli moduli e utilizzare il sistema "richiedi" per importare secondo necessità. Puoi anche "esaminare" le definizioni degli schemi da oggetti "modelli" se non vuoi "modulare" tutto.

Per lo più, però, ti consente di specificare chiaramente "cosa vuoi" per le impostazioni predefinite.

Per un default più complesso, probabilmente vorrai farlo in un hook "pre-salvataggio". Come esempio più completo:

var async = require('async'),
    mongoose = require('mongoose'),
    Schema = mongoose.Schema;

var paramSchema = new Schema({
  "name": { "type": String, "default": "something" },
  "value": { "type": String, "default": "something" }
});

var featureSchema = new Schema({
  "name": { "type": String, "default": "something" },
  "params": [paramSchema]
});

var appSchema = new Schema({
  "appFeatures": [featureSchema]
});

appSchema.pre("save",function(next) {
  if ( !this.appFeatures || this.appFeatures.length == 0 ) {
    this.appFeatures = [];
    this.appFeatures.push({
      "name": "something",
      "params": []
    })
  }

  this.appFeatures.forEach(function(feature) {
    if ( !feature.params || feature.params.length == 0 ) {
      feature.params = [];
      feature.params.push(
       {  "name": "a", "value": "A" },
       {  "name": "b", "value": "B" }
      );
    }
  });
  next();
});


var App = mongoose.model( 'App', appSchema );

mongoose.connect('mongodb://localhost/test');


async.series(
  [
    function(callback) {
      App.remove({},function(err,res) {
        if (err) throw err;
        callback(err,res);
      });
    },
    function(callback) {
      var app = new App();
      app.save(function(err,doc) {
        if (err) throw err;
        console.log(
          JSON.stringify( doc, undefined, 4 )
        );
        callback()
      });
    },
    function(callback) {
      App.find({},function(err,docs) {
        if (err) throw err;
        console.log(
          JSON.stringify( docs, undefined, 4 )
        );
        callback();
      });
    }
  ],
  function(err) {
    if (err) throw err;
    console.log("done");
    mongoose.disconnect();
  }
);

Puoi ripulirlo ed esaminare il percorso dello schema per ottenere valori predefiniti ad altri livelli. Ma in pratica vuoi dire che se quell'array interno non è definito, compilerai i valori predefiniti come codificati.