json 序列化为数组

时间:2022-07-02 07:37:40

我们通常从后台取到json格式的数据到前台进行展示,在这个过程中可能户遇到一些json格式不是自己想要的格式,今天本人就遇到一个棘手的问题,最后在师傅的协助下才进行了正确格式的转换。

可以说最悲哀的莫过于后台可以正确的取到数据,然后在绑定的过程中去发现json格式死活都不对,这是很悲剧的事情,但是解决的办法总是有的,只是今天走了很多弯路,希望把这个问题记下来,防止以后再遇到类似的问题后卡壳

今天遇到的一个问题是这样的:

在做图表的过程中,需要绑定格式为

  [['item1',value1],['item2',value2],...]

      在这里的item和value都是后台的取到的一个值,如何直接序列化对象的话,结果如下:

[["filed1":'item1',"filed2":'value1'],["filed1":'item2',"filed2":'value2']]

很显然这样的结果不是我想要的,

折腾了快一下午没整出来后,请师傅帮忙看一下,他做出以下改进,拿出来和大家共勉。

首先申明一个结果集合,然后再循环已经得到的  item-value键值对集,最后序列化结果集合即可;

现在总结如下:

1.首先得到你想要的字段集合

2.你要得到的json格式中有多少个[];就需要包含几层集合对象

3.序列化大结合集合既可以

部分代码如下:

 //想要得到的数据集合
Dictionary<string,double> dic=new Dictionary<string,double>();
//具体获取方法..... //申明最终想要的json格式集合
List<object> listResult=new List<object>();
for(int i=0;i<=dic.count();i++)
{
//因为我想得到的格式为[[]],所以需要两次嵌套,里面的[]表示一个对象
List<object> listitem=new List<object>();
listitem.add(dic.ToList()[i].key);
listitem.add(dic.ToList()[i].value); //再将上面的两个集合添加到结果集合中
listResult.Add(listitem);
} //然后再序列化即可得到
[[],[]]格式 //以上代码没有在任何IED中进行编码,纯属手敲,如复制会报错,仅仅提供部分思路和参考

仅提供思路,仅供参考,欢迎评论!!!