Javascript 添加到对象而不是覆盖它
我正在使用以下代码Javascript 添加到对象而不是覆盖它,javascript,object,overwrite,Javascript,Object,Overwrite,我正在使用以下代码 $scope.createAuction = function () { var auction = { auction: { langData: {} } }; if($scope.selected.tab === $scope.infoTabs[0]) { Object.assign(auction.auction, { type: 'account', layout: $scope.selecte
$scope.createAuction = function () {
var auction = { auction: { langData: {} } };
if($scope.selected.tab === $scope.infoTabs[0]) {
Object.assign(auction.auction, {
type: 'account',
layout: $scope.selected.description
});
if(auction.auction.layout === 1) {
for(var i = 0, l = $scope.langInput.values.length; i < l; i++) {
auction.auction.langData[$scope.langInput.values[i].selected] = {
name: $scope.inputs.auction_name_account[i + 1]
};
}
for(var i = 0, l = $scope.langInput.values.length; i < l; i++) {
auction.auction.langData[$scope.langInput.values[i].selected] = {
description: 'a'
}
}
}
}
console.log(JSON.stringify(auction));
}
但是我的代码正在覆盖
“pl”
和“eng”
,因此结果是我只能看到描述。在第二个循环中,插入描述属性,而不是覆盖对象:
for(var i = 0, l = $scope.langInput.values.length; i < l; i++) {
auction.auction.langData[$scope.langInput.values[i].selected].description = 'a';
}
for(var i=0,l=$scope.langInput.values.length;i
如果选择,也可以组合循环:
for (var i = 0, l = $scope.langInput.values.length; i < l; i++) {
auction.auction.langData[$scope.langInput.values[i].selected] = {
name: $scope.inputs.auction_name_account[i + 1],
description: 'a'
};
}
for(var i=0,l=$scope.langInput.values.length;i
for (var i = 0, l = $scope.langInput.values.length; i < l; i++) {
auction.auction.langData[$scope.langInput.values[i].selected] = {
name: $scope.inputs.auction_name_account[i + 1],
description: 'a'
};
}