Skip to content

带有树结构的数组(含parent_id)非递归生成包含层级的树结构数组

License

Notifications You must be signed in to change notification settings

clouds-flight/array-tree

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

array-tree

带有树结构的数组(含parent_id)非递归生成包含层级的树结构数组

只是遍历了一遍所有数据,和指定父元素及其下所有子元素,未使用递归,理论上可以支持无限层级

原始结构

json编码后结构如下:
   [{
       "id": "1",
       "parent_id": "0",
       "name": "插件中心"
   }, {
       "id": "2",
       "parent_id": "1",
       "name": "钩子管理"
   }, {
       "id": "3",
       "parent_id": "2",
       "name": "钩子插件管理"
   }, {
       "id": "4",
       "parent_id": "2",
       "name": "钩子插件排序"
   }, {
       "id": "5",
       "parent_id": "2",
       "name": "同步钩子"
   }, {
       "id": "6",
       "parent_id": "0",
       "name": "设置"
   }, {
       "id": "7",
       "parent_id": "6",
       "name": "友情链接"
   }, {
       "id": "8",
       "parent_id": "7",
       "name": "添加友情链接"
   }, {
       "id": "9",
       "parent_id": "7",
       "name": "添加友情链接提交保存"
   }]

生成包含层级结构的数组

ArrayTree::getTree($array,id);  //$array 包含树结构关系的数组(需包含 id  parent_id name),$id 父id ,会返回该父id下的所有子级元素(层级结构)
结果如下:
[{
    "id": "1",
    "parent_id": "0",
    "name": "插件中心",
    "children": [{
	    "id": "2",
	    "parent_id": "1",
	    "name": "钩子管理",
	    "children": [{
		    "id": "3",
		    "parent_id": "2",
		    "name": "钩子插件管理",
		    "children": []
	    }, {
		    "id": "4",
		    "parent_id": "2",
		    "name": "钩子插件排序",
		    "children": []
	    }, {
		    "id": "5",
		    "parent_id": "2",
		    "name": "同步钩子",
		    "children": []
	    }]
    }]
    }, {
    "id": "6",
    "parent_id": "0",
    "name": "设置",
    "children": [{
	    "id": "7",
	    "parent_id": "6",
	    "name": "友情链接",
	    "children": [{
	    	"id": "8",
	    	"parent_id": "7",
	    	"name": "添加友情链接",
    		"children": []
    	       }, {
	    	"id": "9",
	    	"parent_id": "7",
	    	"name": "添加友情链接提交保存",
	    	"children": []
	    }]
    }]
}]

生成包含层级结构的数组,并添加名称路径

ArrayTree::getTreePath($res,$id,$separator);  //$array 包含树结构关系的数组(需包含 id  parent_id name),$id 父id ,会返回该父id下的所有子级元素(层级结构),$separator 路径分隔符
结果如下(分隔符是/,因转为json字符串添加了转义符,解码后是没有\的):
[{
    "id": "1",
    "parent_id": "0",
    "name": "插件中心",
    "path": "插件中心",
    "children": [{
	    "id": "2",
	    "parent_id": "1",
	    "name": "钩子管理",
	    "path": "插件中心\/钩子管理",
	    "children": [{
		    "id": "3",
		    "parent_id": "2",
	            "name": "钩子插件管理",
	            "path": "插件中心\/钩子管理\/钩子插件管理",
	    	    "children": []
    	       }, {
		"id": "4",
	    	"parent_id": "2",
	    	"name": "钩子插件排序",
	    	"path": "插件中心\/钩子管理\/钩子插件排序",
	    	"children": []
    	      }, {
	    	"id": "5",
	    	"parent_id": "2",
	    	"name": "同步钩子",
    		"path": "插件中心\/钩子管理\/同步钩子",
	    	"children": []
    	}]
    }]
        }, {
         "id": "6",
         "parent_id": "0",
        "name": "设置",
        "path": "设置",
        "children": [{
	    "id": "7",
    	    "parent_id": "6",
    	    "name": "友情链接",
    	    "path": "设置\/友情链接",
    	    "children": [{
	    	    "id": "8",
	    	    "parent_id": "7",
	        	"name": "添加友情链接",
	        	"path": "设置\/友情链接\/添加友情链接",
	        	"children": []
    	           }, {
	        	"id": "9",
	        	"parent_id": "7",
	        	"name": "添加友情链接提交保存",
	        	 path": "设置\/友情链接\/添加友情链接提交保存",
	        	"children": []
    	    }]
        }]
    }]

获取父元素所有子元素id的集合

ArrayTree::getChildrenIdArray($array,$id);  //$array 包含树结构关系的数组(需包含 id  parent_id name),$id 父id ,会返回该父id下的所有子级元素id的集合
结果如下:
["1","6","2","7","3","4","5","8","9"]

About

带有树结构的数组(含parent_id)非递归生成包含层级的树结构数组

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages