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

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,最后显示到界面的样子就是:

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

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


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/106330.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • hadoop集群启动步骤

    hadoop集群启动步骤hadoop集群启动步骤

    2022年4月23日
    63
  • 全套电商ERP源代码出售,电商ERP管理系统、电商仓储管理系统、电商分销管理系统[通俗易懂]

    全套电商ERP源代码出售,电商ERP管理系统、电商仓储管理系统、电商分销管理系统[通俗易懂]技术架构:后端C#.net4.5ORMWEBAPI分布式REDIS,前端:VUEAntDesignAggrid(前后端完全分离)1,产品定位:电商ERP管理系统、电商仓储管理系统、电商分销管理系统2,对接了淘宝天猫、京东、拼多多等主流电商平台50+3,多租户4,分布式5,单客户日均100万数据处理能力6,完整导入导出方案7,前端界面自动生成(表格、搜索条件、编辑字段)8,完整开放平台9,微信小程序10,高度可定制的打印方案11,核心功能模块:订单管

    2022年9月20日
    1
  • 中兴F450光猫设置桥接_电信光猫改桥接后上不了网络

    中兴F450光猫设置桥接_电信光猫改桥接后上不了网络前几天突然想搞外网访问,但是电信这款光猫DMZ不能用让我很愁,后来经过一番了解可以让光猫只负责光数转换,剩下的事情交给路由,但是要把光猫设置成桥接模式这个光猫比较特殊不需要进入超级管理员只需要下面这个链接:http://192.168.1.1:8080/bridge_route.gch会出现这个页面,点击桥接复原就行,我是已经点过了,所以置灰了。…

    2022年10月8日
    5
  • idea社区版创建web项目_不用框架写一个web项目

    idea社区版创建web项目_不用框架写一个web项目IDEA社区版搭建Tomcat服务器并创建web项目目标问题实现步骤目标拥有和专业版创建Web项目的目录结构IDEA社区版可以启动Tomcat服务器编写Servlet并访问成功问题IDEA社区版没有创建Web工程的选项IDEA社区版没有Tomcat插件实现步骤针对以上两个问题,分步解决问题一:IDEA社区版没有创建Web工程的选项创建普通的java项目,此处不再赘述构建web项目的目录结构在WEN-INF文件夹下新建web.xml<?xmlvers

    2022年9月22日
    2
  • ioctl() FIONREAD 检测socket是否有数据可读

    ioctl() FIONREAD 检测socket是否有数据可读先看看FIONREAD的作用FIONREAD:Getthenumberofbytesintheinputbuffer获取接收缓存中数据的字节数项目中用来判断tcpsocket是否有数据接收到,但是出现了一个问题,对于用于accept的socket即调用listen()之后的socket,用FIONREAD,判断的时候报错,ioctl()返回-1,错误码是2…

    2022年7月23日
    7
  • php二维码分享到朋友圈,php实现的微信分享到朋友圈并记录分享次数功能

    php二维码分享到朋友圈,php实现的微信分享到朋友圈并记录分享次数功能本文实例讲述了php实现的微信分享到朋友圈并记录分享次数功能。分享给大家供大家参考,具体如下:1.引入JS文件2.通过config接口注入权限验证配置3.通过ready接口处理成功验证4.通过error接口处理失败验证JSDK档说明:https://mp.weixin.qq.com/wiki/7/aaa137b55fb2e0456bf8dd9148dd613f.html(1)(2)页面加入获取we…

    2022年6月6日
    29

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号