在javascript中从数组生成多级对象
我有一个事件数组,我想在这些数组的对象之间建立关系。 数组: 我知道我想让这种关系在javascript中从数组生成多级对象,javascript,arrays,Javascript,Arrays,我有一个事件数组,我想在这些数组的对象之间建立关系。 数组: 我知道我想让这种关系 { "area": "punjab", "site": [ { "name": "lahore", "link": [ { "name": "http://sargodha.com", } ] }, { "name": "sargodha", "link": [
{
"area": "punjab",
"site": [
{
"name": "lahore",
"link": [
{
"name": "http://sargodha.com",
}
]
},
{
"name": "sargodha",
"link": [
{
"name": "http://sargodha.com",
}
]
}
]
},
{
"area": "sindh",
"site": [
{
"name": "karachi",
"link": [
{
"name": "http://karachi.com",
}
]
}
}
这是我写的代码:
function isinarrayfilters(matchingObject, targetArray, key) {
var existindex = -1;
$.each(targetArray, function(index, array) {
if (array.key == matchingObject.key) {
//Object exist in array
existindex = index;
}
});
return existindex;
}
generatedRelationArray = [];
$.each(alertsJson, function(index, alertJson) {
inarrayindex = isinarrayfilters(alertJson.area, relationArray,'area');
if (inarrayindex == -1) {
key = alertJson.site
generatedsites = {
"area": alertJson.area,
"site": []
}
relationArray.push(generatedsites);
}
});
了解任何人指导我如何将站点附加到相关区域
- 我必须再次运行循环,尝试检查exist方法并获取索引,然后将站点推入其中
数据中
var res = data.groupBy(function(e){ return e.area; });
这将创建一个稍微不同的结构:
{
"punjab" : [{
'area': 'punjab',
'site': 'lahore',
'link': 'http: //lahore.com'
}, {
'area': 'punjab',
'site': 'sargodha',
'link': 'http: //sargodha.com'
}, {
'area': 'punjab',
'site': 'multan',
'link': 'http: //multan.com'
}],
"sindh": [...]
}
如果您需要这个显式结构,那么您可以这样做
var res = data.groupBy(function(e){ return e.area; })
.each(function(e){
return {
area : e.key,
site : e.value.select(function(e){
return {
name : e.site,
linkm : [e.link]
};
});
});
我已经创建了一个用于解释什么是查询js以及如何使用它的示例一个保留格式的答案:
var generate = function(list) {
var resultList = [];
var tmpStoreRef = {};
$.each(list, function(id, item) {
var area = item.area
,site = item.site
,link = item.link;
if (typeof tmpStoreRef[area] === 'undefined') {
tmpStoreRef[area] = {
area: area,
site: []
}
resultList.push(tmpStoreRef[area]);
}
tmpStoreRef[area].site.push({
name: site,
link: link
});
});
return resultList;
};
var generate = function(list) {
var resultList = [];
var tmpStoreRef = {};
$.each(list, function(id, item) {
var area = item.area
,site = item.site
,link = item.link;
if (typeof tmpStoreRef[area] === 'undefined') {
tmpStoreRef[area] = {
area: area,
site: []
}
resultList.push(tmpStoreRef[area]);
}
tmpStoreRef[area].site.push({
name: site,
link: link
});
});
return resultList;
};