JavaScript打印JSON对象 - 树形结构输出 - 格式化JSON数组 - JS从一维数组 生成树形结构对象

Posted Rudon滨海渔村

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript打印JSON对象 - 树形结构输出 - 格式化JSON数组 - JS从一维数组 生成树形结构对象相关的知识,希望对你有一定的参考价值。

效果图

方法

// 格式化对象,使用四个空格缩进
function get_formatted_string (objectOrArray) 
    return JSON.stringify(objectOrArray, null, 4)


// 数组对象
let data = [
    
        "menuId": 1,
        "menuName": "XX后台",
        "parentId": 0,
        "isFrame": "1",
        "status": "0",
        "children": [
            
                "menuId": 100,
                "menuName": "XX菜单",
                "parentId": 1,
                "isFrame": "1",
                "status": "0",
                "children": [
                    
                        "menuId": 1000,
                        "menuName": "基础功能",
                        "parentId": 100,
                        "isFrame": "1",
                        "status": "0",
                        "children": [
                            
                                "menuId": 1001,
                                "menuName": "订单管理",
                                "parentId": 1000,
                                "isFrame": "1",
                                "status": "0"
                            ,
                            
                                "menuId": 1002,
                                "menuName": "商品管理",
                                "parentId": 1000,
                                "isFrame": "1",
                                "status": "0"
                            
                        ]
                    ,
                    
                        "menuId": 1013,
                        "menuName": "页面管理",
                        "parentId": 100,
                        "isFrame": "1",
                        "status": "0",
                        "children": [
                            
                                "menuId": 1014,
                                "menuName": "轮播图管理",
                                "parentId": 1013,
                                "isFrame": "1",
                                "status": "0"
                            ,
                            
                                "menuId": 1015,
                                "menuName": "新品推荐",
                                "parentId": 1013,
                                "isFrame": "1",
                                "status": "0"
                            
                        ]
                    
                ]
            ,
            
                "menuId": 101,
                "menuName": "数据导出",
                "parentId": 1,
                "isFrame": "1",
                "status": "0",
                "children": [
                    
                        "menuId": 1018,
                        "menuName": "月销售",
                        "parentId": 101,
                        "isFrame": "1",
                        "status": "0"
                    ,
                    
                        "menuId": 1019,
                        "menuName": "季销售",
                        "parentId": 101,
                        "isFrame": "1",
                        "status": "0"
                    
                ]
            
        ]
    
];



let string = get_formatted_string( data );

// 使用textarea输出保留换行格式的string即可


JS从一维数组 生成树形结构对象

data是一维数组

id、parentId非必填,用来指定每个记录的id和 父节点id的 下标

children是输出子元素的下标(会自动创建此下标)

function handleTree(data, id, parentId, children) 
	let config = 
		id: id || 'id',
		parentId: parentId || 'parentId',
		childrenList: children || 'children'
	;

	var childrenListMap = ;
	var nodeIds = ;
	var tree = [];

	for (let d of data) 
		let parentId = d[config.parentId];
		if (childrenListMap[parentId] == null) 
			childrenListMap[parentId] = [];
		
		nodeIds[d[config.id]] = d;
		childrenListMap[parentId].push(d);
	

	for (let d of data) 
		let parentId = d[config.parentId];
		if (nodeIds[parentId] == null) 
			tree.push(d);
		
	

	for (let t of tree) 
		adaptToChildrenList(t);
	

	function adaptToChildrenList(o) 
		if (childrenListMap[o[config.id]] !== null) 
			o[config.childrenList] = childrenListMap[o[config.id]];
		
		if (o[config.childrenList]) 
			for (let c of o[config.childrenList]) 
				adaptToChildrenList(c);
			
		
	

	console.log(childrenListMap);
	return tree;

以上是关于JavaScript打印JSON对象 - 树形结构输出 - 格式化JSON数组 - JS从一维数组 生成树形结构对象的主要内容,如果未能解决你的问题,请参考以下文章

JavaScript打印JSON对象 - 树形结构输出 - 格式化JSON数组 - JS从一维数组 生成树形结构对象

Javascript中扁平化数据结构与JSON树形结构转换详解

JavaScript实现扁平数组结构与JSON树形结构相互转换递归reducecontinuepushconcatfor of

多叉树结合JavaScript树形组件实现无限级树形结构(一种构建多级有序树形结构JSON(或XML)数据源的方法)

JavaScript扁平数组结构转换成JSON树形结构无限极forEachpushchildren

JavaScript递归方法 生成 json tree 树形结构数据