0

如何在另一个对象中动态创建一个对象?

我得到了这个代码:

var lista = [{
        "product": "Dipers",
        "quantity": 2
    },
    {
        "product": "Beear",
        "quantity": 6
    },
    {
        "product": "Bread",
        "quantity": 10
    }
];

但我需要添加新对象,所以它看起来像这样:

var lista = [{
        "product": "Dipers",
        "quantity": 2

        seller1 = {
        "name": "B&J",
        "adress": "that street"
        }
        seller2 = {
        "name": "B&J",
        "adress": "that street"
        }

    },
    {
        "product": "Beear",
        "quantity": 6
    },
    {
        "product": "Bread",
        "quantity": 10
    }
];

我将如何动态添加seller1seller2现有对象lista

4

5 回答 5

0

我建议将卖家存储在一个数组中,然后使用push

var lista = [{
        "product": "Dipers",
        "quantity": 2

        sellers:[{
        "name": "B&J",
        "adress": "that street"
        },
        {
        "name": "B&J",
        "adress": "that street"
        }]

    },
    {
        "product": "Beear",
        "quantity": 6
    },
    {
        "product": "Bread",
        "quantity": 10
    }
];

然后,在您的代码中,动态添加卖家:

lista[desiredindex].sellers.push({name:"new",address:"new"});
于 2019-01-26T13:10:20.480 回答
0

您的代码中有语法错误,但据我了解,您需要这个

 const seller1Name = “seller1”;
 const seller2Name = “seller2”;
 const lista = [{
    "product": "Dipers",
    "quantity": 2
   },
   {
    "product": "Beear",
    "quantity": 6
   },
   {
    "product": "Bread",
    "quantity": 10
   }
 ];
 lista[0][seller1Name] = {
   "name": "B&J",
   "adress": "that street"
 }

 lista[0][seller2Name] = {
     "name": "B&J",
     "adress": "that street"
 }
于 2019-01-26T13:14:13.380 回答
0

只需将您编写/检索的新对象属性分配给一个新变量,然后简单地使用点符号来检索新属性并将其分配给您的对象。

检查并运行以下代码片段以获取我上面描述的实际示例:

var lista = [{
        "product": "Dipers",
        "quantity": 2
    },
    {
        "product": "Beear",
        "quantity": 6
    },
    {
        "product": "Bread",
        "quantity": 10
    }
];

let newObj = {
  "seller1": {
    "name": "B&J",
    "adress": "that street"
  },
  "seller2": {
    "name": "B&J",
    "adress": "that street"
  }
}

lista[0].seller1 = newObj.seller1;
lista[0].seller2 = newObj.seller2;

console.log(lista);


注意对象属性使用冒号:而不是等号=

于 2019-01-26T13:15:35.727 回答
0

这样做..

var lista = [{
        "product": "Dipers",
        "quantity": 2
    },
    {
        "product": "Beear",
        "quantity": 6
    },
    {
        "product": "Bread",
        "quantity": 10
    }
];
///  try this


lista[0]['seller1']={
        "name": "B&J",
        "adress": "that street"
        };
lista[0]['seller2']={
        "name": "B&J",
        "adress": "that street"
        };
于 2019-01-26T13:18:11.723 回答
0

正如 SomoKRoceS 上面回答的那样,您可以这样编写脚本:

var lista = [{
        "product": "Dipers",
        "quantity": 2,
        "sellers": []
    },
    {
        "product": "Beear",
        "quantity": 6,
        "sellers": []
    },
    {
        "product": "Bread",
        "quantity": 10,
        "sellers": []
    }
];

var seller1 = {
    "name": "B&J",
  "adress": "that street"
}

var seller2 = {
    "name": "Test",
  "adress": "that street"
}

lista[0].sellers.push(seller1);
lista[1].sellers.push(seller2);
lista[2].sellers.push(seller1);
lista[2].sellers.push(seller2);

console.log(lista);

https://jsfiddle.net/9ar58teo/

于 2019-01-26T13:24:21.373 回答