使用ng-model定义猫鼬模式对象数组



我现在是一个编码新手,所以如果提供的材料不够清楚,请耐心等待,我会尽力的。

问题在这里

{ 
    email: 'asdf',
    password: 'asdf',
    userlists: { 
        list1: [ [Object], [Object], [Object] ] 
    } 
}

我希望终端以字符串的形式返回对象数组。

我正在尝试使用这个模式,

user.js

var mongoose = require('mongoose');
module.exports = mongoose.model('User', {
    email: String,
    password: String,
    userlists: {
        list1: {type:{ sublist1: String }},
        list2: {type:{ sublist2: String }}
    }
});

我尝试将userlists设置为对象数组,这返回相同的不需要的结果,以及list1list2的空数组,如果它们没有填充。

我想让用户使用我下面的$http.post方法和ng-model,我使用ngTagsInput指令让用户在注册时选择预制的"标签"。

signup-controller.js

 $scope.createUser = function(){
     console.log($scope.newUser);
     $http.post('api/user/signup', $scope.newUser)
     .success(function(response){
     })
     .error(function(error){
         console.log(error);
     })
 };

signup.html

<button ng-click="createUser()">Submit</button>
    <hr>
       <div>
        <tags-input ng-model="newUser.userlists.list1" display-property="sublist1">
          <auto-complete     source="tagsLoadedFromNgTagsInput($query)" 
                            min-length="1" 
                            load-on-focus="true"    
                            load-on-empty="true">
          </auto-complete>
        </tags-input>
       </div>

这是我从服务器终端执行时得到的结果。我希望数组中的对象显示为字符串,由上面的sign .html中的输入设置。

{ 
    email: 'asdf',
    password: 'asdf',
    userlists: { 
        list1: [ [Object], [Object], [Object] ] 
    } 
}

下面是在mongo shell中记录db.users.find().pretty()的结果:

{
    "_id" : ObjectId("57efd2dbdcb311107b4830b2"),
    "email" : "asdf",
    "password" : "asdf",
    "userlists" : {
        "list1" : [
            {
                "sublist1" : "sometag1",
                "_id" : "57ed472b0c868aafab696b61"
            },
            {
                "sublist1" : "sometag2",
                "_id" : "57ed472b0c868aafab696b62"
            },
            {
                "sublist1" : "sometag3",
                "_id" : "57ed472b0c868aafab696b63"
            }
        ]
    },
    "__v" : 0
}

有人知道我在这里做错了什么吗?

console.log函数在显示对象之前对其进行包装。为了确保显示所有数据,必须在调用控制台之前使用JSON.stringify将其转换为字符串。

// Your object
var obj = {some: {nested: {object: {definition: 'hello world!'}}}};
// Print as a single line
console.log(JSON.stringify(obj));
// Print with 2 spaces identation
console.log(JSON.stringify(obj, null, 2));

使用ng-repeat,因为list1是一个数组。

 <tags-input ng-repeat="list in newUser.userlists.list1">
                <div>{{list.sublist1}}</div>
 </tags-input>

相关内容

  • 没有找到相关文章

最新更新