gpt4 book ai didi

javascript - 动态创建嵌套 JSON 对象父级和子级

转载 作者:行者123 更新时间:2023-11-27 23:02:16 25 4
gpt4 key购买 nike

我正在尝试创建一个像这样的嵌套对象:

[{
"Countrys":{
"CountryCode":"AF",
"CountryName":"AFGHANISTAN",
"CreatedBy":"admin@mail.com",
"CreatedOn":null,
"ModifiedBy":"Admin",
"ModifiedOn":"/Date(1394094559000)/"
},
"StateCode":"BAM",
"CountryCode":"AF",
"StateName":"BAMIAN",
"CreatedBy":"admin@mail.com",
"CreatedOn":"/Date(1372617000000)/",
"ModifiedBy":null,
"ModifiedOn":null
},
...........
]

我的代码:

    updateStateList = [];
//state countrys data variable
var stateCountrysCountryCode;
var stateCountrysCountryName;
var stateCountrysCreatedBy;
var stateCountrysCreatedOn;
var stateCountrysModifiedBy;
var stateCountrysModifiedOn;

//state open data variable
var StateCode;
var CountryCode;
var StateName;
var CreatedBy;
var CreatedOn;
var ModifiedBy;
var ModifiedOn;

$(".tableRow").each(function () {

stateCountrysCountryCode = $(this).find("#erSLCountrysCountryCode").val();
stateCountrysCountryName = $(this).find("#erSLCountrysCountryName").val();
stateCountrysCreatedBy = $(this).find("#erSLCountrysCreatedBy").val();
stateCountrysCreatedOn = $(this).find("#erSLCountrysCreatedOn").val();
stateCountrysModifiedBy = $(this).find("#erSLCountrysModifiedBy").val();
stateCountrysModifiedOn = $(this).find("#erSLCountrysModifiedOn").val();

StateCode = $(this).find("#erSLStateCode").val();
CountryCode = $(this).find("#erSLCountryCode").val();
StateName = $(this).find("#erSLStateName").val();
CreatedBy = $(this).find("#erSLCreatedBy").val();
CreatedOn = $(this).find("#erSLCreatedOn").val();
ModifiedBy = $(this).find("#erSLModifiedBy").val();
ModifiedOn = $(this).find("#erSLModifiedOn").val();

CountrysObj = {};
CountrysObj["CountryCode"] = stateCountrysCountryCode;
CountrysObj["CountryName"] = stateCountrysCountryName;
CountrysObj["CreatedBy"] = stateCountrysCreatedBy;
CountrysObj["CreatedOn"] = stateCountrysCreatedOn;
CountrysObj["ModifiedBy"] = stateCountrysModifiedBy;
CountrysObj["ModifiedOn"] = stateCountrysModifiedOn;

//state open data
statesObj = {};
statesObj["StateCode"] = StateCode;
statesObj["CountryCode"] = CountryCode;
statesObj["StateName"] = StateName;
statesObj["CreatedBy"] = CreatedBy;
statesObj["CreatedOn"] = CreatedOn;
statesObj["ModifiedBy"] = ModifiedBy;
statesObj["ModifiedOn"] = ModifiedOn;




//CountrysObj.push(statesObj["StateCode"]);

updateStateList.push({ "Countrys": CountrysObj });
updateStateList.push(statesObj);

});



alert(JSON.stringify(updateStateList));

我变得像这样的 Json:

[{"Countrys":{"CountryCode":"AX","CountryName":"ALAND ISLANDS","CreatedBy":"admin@mail.com","CreatedOn":"","ModifiedBy":"Admin","ModifiedOn":"/Date(1394094559000)/"}},{"StateCode":"NS","CountryCode":"AX","StateName":"NOT SPECIFIED","CreatedBy":"admin@mail.com","CreatedOn":"/Date(1372617000000)/","ModifiedBy":"","ModifiedOn":""}]

在这个结果中,我得到了额外的第二个右大括号。

最佳答案

在 Javascript 中,执行以下操作:

x = {}

创建一个对象。这就是为什么将它添加(插入)到数组中会产生以下结果 [{}]

您想要的是创建一个包含所有状态数据的对象,并将 countries 作为该对象的属性。

像这样:

//state open data
statesObj = {};
statesObj["StateCode"] = StateCode;
statesObj["CountryCode"] = CountryCode;
statesObj["StateName"] = StateName;
statesObj["CreatedBy"] = CreatedBy;
statesObj["CreatedOn"] = CreatedOn;
statesObj["ModifiedBy"] = ModifiedBy;
statesObj["ModifiedOn"] = ModifiedOn;
statesObj["Countries"] = CountrysObj;

关于javascript - 动态创建嵌套 JSON 对象父级和子级,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36976593/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com