java如何将json数据转化为数组类型?

大哥有没有人讲详细点的,我想问下,java如何将json数据转化为数组类型?
最新回答
鸿笺钟书

2024-11-29 08:07:22

JSON数据处理方法详解

一、JSON对象与JSON字符串转换

在数据传输中,JSON数据通常以字符串形式传递,而JavaScript操作的是JSON对象,因此JSON对象和JSON字符串之间的相互转换至关重要。例如:

JSON字符串:var jsonStr = '{"name":"Liza", "password":"123"}';

JSON对象:var jsonObj = {"name":"Liza", "password":"123"};

1. JSON字符串转换JSON对象:var jsonObject = jQuery.parseJSON(jsonstr);

2. JSON对象转换JSON字符串:var jsonstr = JSON.stringify(jsonObject );

二、JSON的输出美化

JSON.stringify()方法可以将JSON对象转换为字符串,同时支持通过可选参数space指定缩进的空格数量,用于美化输出。该参数上限为10,小于1则无空格,未提供或为null则无空格。例如:

JSON对象:var jsonObject = {"root":{"id":"1","text":"复选框","layout":"map","children":[{"id":"1.1","text":"必填项验证","side":"right"},{"id":"1.2","text":"选中后状态","side":"left"},{"id":"1.3","text":"未选择状态,默认显示样式","side":"middle"}]};

美化输出:var formatJsonStr = JSON.stringify(jsonObject,undefined,2);

三、JSON字符串替换

在处理JSON字符串时,可能需要将特定的字符进行替换,如将' \\" ' 替换成 ' " ' 。可以使用replace方法实现,设置正则表达式进行全局替换:

JSON字符串:var jsonStr = '{\"root\":{\"id\":\"1\",\"text\":\"复选框\",\"layout\":\"map\",\"children\":[{\"id\":\"1.1\",\"text\":\"必填项验证\",\"side\":\"right\"},{\"id\":\"1.2\",\"text\":\"选中后状态\",\"side\":\"left\"},{\"id\":\"1.3\",\"text\":\"未选择状态,默认显示样式\",\"side\":\"middle\"}]}}';

替换后:var jsonStr = jsonstr.replace(new RegExp('\\"',"gm"),'"');

四、JSON对象与数组遍历

遍历JSON对象与数组是数据处理中常见的需求。例如:

遍历JSON对象:var packJson = {"name":"Liza", "password":"123"};

遍历代码:for(var k in packJson){console.log(k + " " + packJson[k]);}

遍历JSON数组:var packJson = [{"name":"Liza", "password":"123"}, {"name":"Mike", "password":"456"}];

遍历代码:for(var i in packJson){console.log(packJson[i].name + " " + packJson[i].password);}

五、递归遍历JSON

实现复杂功能时,递归遍历JSON对象非常有用。以下给出两个递归遍历JSON的例子:

示例1:删除数组中超过一个对象后的所有对象。

原始JSON:{ "root": { "id": "1", "text": "复选框", "layout": "map", "children": [ { "id": "1.1", "text": "必填项验证", "side": "right", "children": [ { "id": "1.1.1", "text": "是" }, { "id": "1.1.2", "text": "否,只能选择" } ] }, { "id": "1.2", "text": "选中后状态", "side": "left" } ] } }

期望处理后的JSON:{ "root": { "id": "1", "text": "复选框", "layout": "map", "children": [ { "id": "1.1", "text": "必填项验证", "side": "right", "children": [ { "id": "1.1.1", "text": "是" } ] } ] } }

递归代码:function jsonParse(jsonObj) {distinctJson(jsonObj);var last=JSON.stringify(jsonObj, undefined, 2);return last;}

示例2:查找目标节点并将目标子节点赋值给目标节点的children。

原始JSON:var obj = { "id": "1", "text": "复选框", "children": [ { "id": "2", "text": "层级关联,不选择上一层级下拉框无法选择" }, { "id": "3", "text": "是否可以手动输入", "children": [ { "id": "4", "text": "是", "children": [ { "id": "5", "text": "检索出符合条件的结果优先展示" } , { "id": "6", "text": "大小写区分" } ] } ] } ] };

目标节点与子节点:var targetChildren = [{ "id": "7", "text": "关联下拉框,选择此下拉框内容" }, { "id": "8", "text": "选中下拉框后显示下拉框内容" }];

递归查找代码:function findTarget(obj,targetId,targetChildren){if(obj.id==targetId){obj.children=targetChildren;return true;}}