如何针对唯一键名/值对“过滤”JSON?

时间:2021-02-07 07:37:28

I've got some JSON data that is giving me a list of languages with info like lat/lng, etc. It also contains a group value that I'm using for icons--and I want to build a legend with it. The JSON looks something like this:

我有一些JSON数据给我一个语言列表,其中包含lat / lng等信息。它还包含我用于图标的组值 - 我想用它构建一个图例。 JSON看起来像这样:

{"markers":[
  {"language":"Hungarian","group":"a", "value":"yes"},
  {"language":"English", "group":"a", "value":"yes"},
  {"language":"Ewe", "group":"b", "value":"no"},
  {"language":"French", "group":"c", "value":"NA"}
]}

And I want to "filter" it to end up like this:

我想“过滤”它最终像这样:

{"markers":[
 {"group":"a", "value":"yes"},
 {"group":"b", "value":"no"},
 {"group":"c", "value":"NA"}
]}

Right now I've got this, using jQuery to create my legend..but of course it's pulling in all values:

现在我已经有了这个,使用jQuery来创建我的传奇......当然,它正在吸引所有的价值观:

$.getJSON("http://127.0.0.1:8000/dbMap/map.json", function(json){
    $.each(json.markers, function(i, language){
        $('<p>').html('<img src="http://mysite/group' + language.group + '.png\" />' + language.value).appendTo('#legend-contents');
    });
});

How can I only grab the unique name/value pairs in the entire JSON object, for a given pair?

对于给定的对,我怎样才能获取整个JSON对象中的唯一名称/值对?

4 个解决方案

#1


6  

I'd transform the array of markers to a key value pair and then loop that objects properties.

我将标记数组转换为键值对,然后循环该对象属性。

var markers = [{"language":"Hungarian","group":"a", "value":"yes"}, 
  {"language":"English", "group":"a", "value":"yes"}, 
  {"language":"Ewe", "group":"b", "value":"no"},
  {"language":"French", "group":"c", "value":"NA"}];

var uniqueGroups = {};
$.each(markers, function() {
  uniqueGroups[this.group] = this.value;
});

then

$.each(uniqueGroups, function(g) {
  $('<p>').html('<img src="http://mysite/group' + g + '.png\" />' + this).appendTo('#legend-contents');
});

or

for(var g in uniqueGroups)
{
  $('<p>').html('<img src="http://mysite/group' + g + '.png\" />' + uniqueGroups[g]).appendTo('#legend-contents');
}

This code sample overwrites the unique value with the last value in the loop. If you want to use the first value instead you will have to perform some conditional check to see if the key exists.

此代码示例使用循环中的最后一个值覆盖唯一值。如果您想使用第一个值,则必须执行一些条件检查以查看密钥是否存在。

#2


2  

How about something more generic?

更通用的东西怎么样?

function getDistinct(o, attr)
{
 var answer = {};
 $.each(o, function(index, record) {
   answer[index[attr]] = answer[index[attr]] || [];
   answer[index[attr]].push(record);
 });

 return answer;    //return an object that has an entry for each unique value of attr in o as key, values will be an array of all the records that had this particular attr.
}

Not only such a function would return all the distinct values you specify but it will also group them if you need to access them.

不仅这样的函数会返回您指定的所有不同值,而且如果您需要访问它们,它也会对它们进行分组。

In your sample you would use:

在您的示例中,您将使用:

$.each(getDistinct(markers, "group"), function(groupName, recordArray)
{ var firstRecord = recordArray[0];
        $('<p>').html('<img src="http://mysite/group' + groupName+ '.png\" />' + firstRecord.value).appendTo('#legend-contents');

}

#3


0  

See this- Best way to query back unique attribute values in a javascript array of objects?

请参阅此 - 查询javascript对象数组中的唯一属性值的最佳方法?

You just need a variation that checks for 2 values rather than 1.

您只需要一个检查2个值而不是1个值的变体。

#4


0  

var markers  = _.uniq( _.collect( markers , function( x ){
                        return JSON.stringify( x ); 
                    })); 

reference

#1


6  

I'd transform the array of markers to a key value pair and then loop that objects properties.

我将标记数组转换为键值对,然后循环该对象属性。

var markers = [{"language":"Hungarian","group":"a", "value":"yes"}, 
  {"language":"English", "group":"a", "value":"yes"}, 
  {"language":"Ewe", "group":"b", "value":"no"},
  {"language":"French", "group":"c", "value":"NA"}];

var uniqueGroups = {};
$.each(markers, function() {
  uniqueGroups[this.group] = this.value;
});

then

$.each(uniqueGroups, function(g) {
  $('<p>').html('<img src="http://mysite/group' + g + '.png\" />' + this).appendTo('#legend-contents');
});

or

for(var g in uniqueGroups)
{
  $('<p>').html('<img src="http://mysite/group' + g + '.png\" />' + uniqueGroups[g]).appendTo('#legend-contents');
}

This code sample overwrites the unique value with the last value in the loop. If you want to use the first value instead you will have to perform some conditional check to see if the key exists.

此代码示例使用循环中的最后一个值覆盖唯一值。如果您想使用第一个值,则必须执行一些条件检查以查看密钥是否存在。

#2


2  

How about something more generic?

更通用的东西怎么样?

function getDistinct(o, attr)
{
 var answer = {};
 $.each(o, function(index, record) {
   answer[index[attr]] = answer[index[attr]] || [];
   answer[index[attr]].push(record);
 });

 return answer;    //return an object that has an entry for each unique value of attr in o as key, values will be an array of all the records that had this particular attr.
}

Not only such a function would return all the distinct values you specify but it will also group them if you need to access them.

不仅这样的函数会返回您指定的所有不同值,而且如果您需要访问它们,它也会对它们进行分组。

In your sample you would use:

在您的示例中,您将使用:

$.each(getDistinct(markers, "group"), function(groupName, recordArray)
{ var firstRecord = recordArray[0];
        $('<p>').html('<img src="http://mysite/group' + groupName+ '.png\" />' + firstRecord.value).appendTo('#legend-contents');

}

#3


0  

See this- Best way to query back unique attribute values in a javascript array of objects?

请参阅此 - 查询javascript对象数组中的唯一属性值的最佳方法?

You just need a variation that checks for 2 values rather than 1.

您只需要一个检查2个值而不是1个值的变体。

#4


0  

var markers  = _.uniq( _.collect( markers , function( x ){
                        return JSON.stringify( x ); 
                    })); 

reference