0

Article スキーマと Tag スキーマがあります。そして、記事への Tag オブジェクト参照の配列を保存しようとしています。 これは私の記事のスキーマです:

var ArticleSchema = new Schema({
 ....
  title: {
    type: String,
    .....
  },
  content: {
   .....
  },
  .....
  tags: [{
    type: Schema.Types.ObjectId,
    ref: 'Tag'
  }]
});

そしてタグスキーマ:

var TagSchema = new Schema({
  name: {
   .....
  },
  user: {
   ......
  },
  count: {
   .....
  }
});

フロントエンドにはコントローラーがあります。

'use strict';

// Articles controller
angular.module('articles').controller('ArticlesController', [
  '$scope', '$stateParams', '$location', 'Authentication', 'Articles', 'Tags', '$filter',
  function($scope, $stateParams, $location, Authentication, Articles, Tags, $filter) {
    $scope.authentication = Authentication;

    // Create new Article
    $scope.create = function(isValid) {
      $scope.error = null;

      if (!isValid) {
        $scope.$broadcast('show-errors-check-validity', 'articleForm');

        return false;
      }

      var tagsArrays = this.tags.replace(/ /g, '').split(',');
      var tagsObjectArray = [];
      for (var i = 0; i < tagsArrays.length; i++) {
        // Create tag object
        var tag = new Tags({
          name: tagsArrays[i]
        });
        tagsObjectArray.push(tag);

        saveATag(tag);
        //article.tags.push(tag);
      }

      function saveATag(tempTag) {
        tempTag.$save(function(response) {
        }, function(errorResponse) {
          $scope.error = errorResponse.data.message;
        });
      }

       // Create new Article object
      var article = new Articles.articles({
        title: this.title,
        content: this.content,
        tags: tagsObjectArray
      });

      // Redirect after save
      article.$save(function(response) {
        $location.path('articles/' + response._id);
      }, function(errorResponse) {
        $scope.error = errorResponse.data.message;
      });
    };

バックエンドには、アーティクル用のコントローラーがあります。

exports.create = function(req, res) {
  var article = new Article(req.body);
  article.user = req.user;
  article.save(function(err) {
    if (err) {
      return res.status(400).send({
        message: errorHandler.getErrorMessage(err)
      });
    } else {
      res.json(article);
    }
  });
};

記事にタグの配列を保存しようとすると、次のエラーが表示されます: Cast to Array failed for value "[object Object]" at path "tags" I have looking around and try multiple ways, but still not get it to storeデータベースで。フロントエンドとバックエンドのすべてのルートが適切に設定されています。

4

2 に答える 2

1

Articles スキーマは、タグ ObjectId の配列を想定しており、これらの ID は Mongoose によって自動的に生成されますが、サーバーに到達するまで生成されません。

タグ サーバー コントローラーから:

var errorHandler = require(path.resolve('./modules/core/server/controllers/errors.server.controller')),
    mongoose = require('mongoose'),
    Tag = mongoose.model('Tag');

exports.createTag = function (req, res) {
    var tag = new Tag(req.body); // tag._id now exists

    tag.save(function (err) {
        if (err) {
            return res.status(400).send({
                message: errorHandler.getErrorMessage(err)

            });
        } 
        else {
            res.json(tag);
        }
    });
};

したがって、フロントエンド コントローラーでは、すべてのタグを保存する必要があります。次に、保存応答から _id フィールドだけを取り出して、それらを記事と共に保存する配列に入れます。$save 関数は非同期であるため、Angular の $q サービス、特に $q.all() 関数を利用して、記事を保存する前にすべてのタグが確実に保存されるようにすることをお勧めします。

var promises = [];
var tag;
var tagIds = [];

for (var i = 0; i < tagsArrays.length; i++) {
    // Create tag object
    tag = new Tags({
        name: tagsArrays[i]
    });

    // $save() returns a promise, so you are creating an array of promises
    promises.push(tag.$save());
}

$q.all(promises)
    .then(function(tags) { 
        // When all the tag.$save() promises are resolved, this function will run
        for(i = 0; i < tags.length; i++) {
            // The response is an array of tag objects, extract the Ids from those objects
            tagIds.push(tags[i]._id);
        }

        var article = new Articles({
            title: this.title,
            content: this.content,
            tags: tagIds
        });

        // Save the article
        return article.$save();
    })
    .then(function(article) {
        // When the article save finishes, this function will run
        $location.path('articles/' + article._id);
    })
    .catch(function(err) {
        console.error(err);
    });
于 2016-03-22T23:12:46.903 に答える