jquery前端递归打印出树状结构的多层复杂map或json键值对数据

从后台传来一组多层结构的复杂map键值对数据,如下:
	 { "custId": "fc2ac08f-3261-407c-b544-c3797b30509b", "extId": null, "operatorId": "", "retCode": null, "retMsg": null, "respSysCode": null, "respSysCodeMsg": null, "respBizCode": null, "respBizCodeMsg": null, "creditData": { "watchList_zmWatchListDetail": [ { "bizCode": "AC", "code": "AC005001", "extendInfo": null, "level": 0, "refreshTime": 1498060800000, "settlement": true, "statement": null, "status": null, "type": "AC005" }, { "bizCode": "AA", "code": "AA001012", "extendInfo": null, "level": 0, "refreshTime": 1498060800000, "settlement": true, "statement": null, "status": null, "type": "AA001" }, { "bizCode": "AA", "code": "AA001001", "extendInfo": null, "level": 0, "refreshTime": 1498060800000, "settlement": true, "statement": null, "status": null, "type": "AA001" }, { "bizCode": "AC", "code": "AC001001", "extendInfo": null, "level": 0, "refreshTime": 1498060800000, "settlement": true, "statement": null, "status": null, "type": "AC001" }, { "bizCode": "AH", "code": "AH001002", "extendInfo": null, "level": 0, "refreshTime": 1498060800000, "settlement": true, "statement": null, "status": null, "type": "AH001" } ], "watchList_isMatched": null }, "creditRemark": { "watchList_zmWatchListDetail": "行业关注清单", "watchList_isMatched": "是否匹配" } }

再控制台显示是下面的样子:

	 {
	 	"custId": "fc2ac08f-3261-407c-b544-c3797b30509b",
	 	"extId": null,
	 	"operatorId": "",
	 	"retCode": null,
	 	"retMsg": null,
	 	"respSysCode": null,
	 	"respSysCodeMsg": null,
	 	"respBizCode": null,
	 	"respBizCodeMsg": null,
	 	"creditData": {
	 		"watchList_zmWatchListDetail": [{
	 				"bizCode": "AC",
	 				"code": "AC005001",
	 				"extendInfo": null,
	 				"level": 0,
	 				"refreshTime": 1498060800000,
	 				"settlement": true,
	 				"statement": null,
	 				"status": null,
	 				"type": "AC005"
	 			}, {
	 				"bizCode": "AA",
	 				"code": "AA001012",
	 				"extendInfo": null,
	 				"level": 0,
	 				"refreshTime": 1498060800000,
	 				"settlement": true,
	 				"statement": null,
	 				"status": null,
	 				"type": "AA001"
	 			}, {
	 				"bizCode": "AA",
	 				"code": "AA001001",
	 				"extendInfo": null,
	 				"level": 0,
	 				"refreshTime": 1498060800000,
	 				"settlement": true,
	 				"statement": null,
	 				"status": null,
	 				"type": "AA001"
	 			}, {
	 				"bizCode": "AC",
	 				"code": "AC001001",
	 				"extendInfo": null,
	 				"level": 0,
	 				"refreshTime": 1498060800000,
	 				"settlement": true,
	 				"statement": null,
	 				"status": null,
	 				"type": "AC001"
	 			}, {
	 				"bizCode": "AH",
	 				"code": "AH001002",
	 				"extendInfo": null,
	 				"level": 0,
	 				"refreshTime": 1498060800000,
	 				"settlement": true,
	 				"statement": null,
	 				"status": null,
	 				"type": "AH001"
	 			}
	 		],
	 		"watchList_isMatched": null
	 	},
	 	"creditRemark": {
	 		"watchList_zmWatchListDetail": "行业关注清单",
	 		"watchList_isMatched": "是否匹配"
	 	}
	 }

这样以json的格式树状显示是不是清晰多了.可是在控制台我们的开发工具会给我们以json的格式显示好,但是浏览器这样的前端页面显示的就是一长串的字符串了,看着十分不清晰,那么怎么在前端jquery代码怎么写呢?当然可以用插件,给出一个json格式的字符串,然后用插件直接打印出,还有漂亮的样式,可这里小编还在研究中,下面说一下花了近两天研究出来的蹩脚代码吧:

1,前端代码:

<div id="table1"></div>

是一个简单的div,用于将整理好的字符串形式的html代码追加到此div下;

2,jquery代码

<script>
var jsonObjw=json1;<!--json是后台传来的数据,即文章最上面的一串json格式的字符串-->
var level=0; <!--用来记录打印多级分支的前面的空格数-->
showall(jsonObjw,level); <!--jquery函数,将数据和记录的空格数作为两个入参-->
function showall(jsonObj,forNum){
	for(var p in jsonObj){ <!-- 循环遍历json数据,p想到与键值对的key-->
		if((typeof jsonObj[p]) == "object" && jsonObj[p] !=null){<!--如果键值对的值的类型是"object",则需要递归显示其下面的数据.即对象类型说明他还有下级,这里类似文件中的目录.-->
			for(var i=0;i<forNum;i++){ <!-- 打印每行数据前需要的空格-->
				parent = parent + "    ";<!-- parent相当于java中的静态字符串,将html代码追加到parent中.本想使用tab键空格,可不知道怎么使用,就用四个空格代替-->
			}
			parent=	parent+"<strong>"+p+"</strong>"+ <!-- 如果是目录则加粗显示.并只显示key值.如果没有key值会自动用0,1,2,代替-->
				    "<br />";<!--换行-->
			showall(jsonObj[p],forNum+1);<!--使用递归,每多一个深一层子级就多循环一次空格-->
		}else{
			if(jsonObj[p]==null || jsonObj[p]==""){<!--如果不是'目录'就直接追加到parent中>
				for(var i=0;i<forNum;i++){
					parent = parent + "    ";
				}
				parent=	parent+ p + "    :    " + ' '+
						"<br />"; 
			}else{
				  for(var i=0;i<forNum;i++){
					  parent =parent + "    ";
				  }
				  parent=parent+ p + "    :    " + jsonObj[p] + 
						 "<br />"; 
			}
		}
	}
	$("#table1").append(parent);<!--将最终的parent追加到id='table'的div中>
	parent="";<!-- 重置parent,保证下次后台传来的数据不会追加到之前的html中.>
}
</script>


3,最后显示到界面的样子就是:

大概就是这个样子,虽然也不是很好看,但是比打印一坨字符串好看多了.


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
可以使用递归来查询树状结构数据。假设你有一个包含父子关系的表,其中每个记录包含一个唯一的ID和一个指向父记录ID的字段。下面是一个示例的PHP代码,用于递归查询树状结构数据: ```php function getChildren($data, $parentId) { $result = array(); foreach ($data as $row) { if ($row['parent_id'] == $parentId) { $children = getChildren($data, $row['id']); if ($children) { $row['children'] = $children; } $result[] = $row; } } return $result; } // 假设你有一个包含树状结构数据的数组 $data = array( array('id' => 1, 'name' => 'Node 1', 'parent_id' => 0), array('id' => 2, 'name' => 'Node 2', 'parent_id' => 0), array('id' => 3, 'name' => 'Node 3', 'parent_id' => 1), array('id' => 4, 'name' => 'Node 4', 'parent_id' => 1), array('id' => 5, 'name' => 'Node 5', 'parent_id' => 2), array('id' => 6, 'name' => 'Node 6', 'parent_id' => 4), ); $tree = getChildren($data, 0); // 打印树状结构数据 echo json_encode($tree); ``` 上述代码中,`getChildren` 函数接收一个数据数组和一个父记录ID作为参数。它遍历数据数组,找到所有具有指定父记录ID的记录,并递归调用 `getChildren` 函数来获取子记录。如果子记录存在,则将其添加到父记录的 `children` 字段中,最后返回结果数组。 在示例中,我们假设根记录的 `parent_id` 为0。你可以根据具体的数据结构进行调整。最后,我们使用 `json_encode` 函数将结果以JSON格式输

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小爷欣欣

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值