
PHP 中处理嵌套数组,核心在于理解其层级结构,并用递归或迭代方式遍历、提取、重组。关键不是硬编码层级,而是识别键名规律、值类型和业务语义。
识别嵌套模式:先看结构再定策略
嵌套数组常见于 API 响应、配置文件或树形数据(如菜单、分类)。例如:
$data = [
'code' => 200,
'data' => [
['id' => 1, 'name' => 'A', 'children' => [['id' => 11, 'name' => 'A1']]],
['id' => 2, 'name' => 'B', 'children' => []]
]
];
这里 data 是列表,每个元素可能含 children 子数组——这是典型的“父子同构”树形结构。拆解前需明确:
• 哪些键承载业务数据(如 id、name)
• 哪些键表示嵌套关系(如 children、items、sub)
• 是否存在多级深度(不限于两级)
扁平化:把多层转成单层索引数组
适合做搜索、导出、批量处理。用递归函数提取所有叶子节点或指定字段:
立即学习“PHP免费学习笔记(深入)”;
- 定义一个空结果数组 $flat = []
- 写递归函数,参数为当前子数组和可选的父级上下文(如 parent_id)
- 遍历当前数组,对每个元素:存基础字段;若存在 children 键且不为空,递归调用自身并传入该 children 和当前 id
- 避免无限递归:检查 children 是否为数组且非空,防止 null 或字符串误入
示例中调用后可得:
[ ['id'=>1,'name'=>'A','parent_id'=>null], ['id'=>11,'name'=>'A1','parent_id'=>1] ]
按需重组:从扁平数据还原树或分组结构
常用于前端渲染菜单、构建分类树。前提是有唯一 ID 和 parent_id 字段:
- 第一遍遍历:用 id 作键暂存所有项,形成 $map = [1 => [...], 11 => [...]]
- 第二遍遍历:对每项,若 parent_id 存在且在 $map 中,将其追加到 $map[$parent_id]['children'] 数组中
- 最后筛选出 parent_id 为空或 0 的项,即为根节点
- 注意:children 键需初始化为空数组,否则追加会报错
键路径提取与动态赋值
当需精准读写某深层字段(如 data.0.children.0.name),可用点号路径解析:
- 将路径 explode('.', $path) 得到键序列 ['data', '0', 'children', '0', 'name']
- 逐层进入数组:$val = $array;foreach ($keys as $key) { $val = $val[$key] ?? null; }
- 写入时类似,但需在每一层检查是否存在,不存在则初始化为数组
- 推荐封装为 getNested($array, $path, $default = null) 和 setNested(&$array, $path, $value)
这种写法比硬写 $arr['data'][0]['children'][0]['name'] 更健壮,尤其面对不确定结构时。











