PHP二维数组降维首选array_merge(...$arr)(PHP 7.4+)或call_user_func_array('array_merge', $arr)(旧版),但需预处理确保子项均为非空数组;降维后必须用array_values()重索引再json_encode(),否则可能输出JSON对象而非数组;遇到resource等非法类型需提前过滤或使用JSON_PARTIAL_OUTPUT_ON_ERROR。

php二维数组降维用array\_merge还是array\_collapse
PHP 8.1+ 才有 array_collapse(),老版本直接用 array_merge(...$arr) 最快也最稳。但注意:如果子数组键名不是纯数字(比如带字符串键),array_merge() 会重置键名或覆盖同名键,导致数据丢失。
常见错误现象:array_merge(...$arr) 返回空数组或只合并了第一个子数组——大概率是 $arr 本身为空、某个子项不是数组,或者用了引用未解引用。
- 确认每个子项都是数组:
array_filter($arr, 'is_array')预处理 - 避免空子数组干扰:
array_values(array_filter($arr, function($v) { return is_array($v) && !empty($v); })) - PHP 7.4+ 可用 splat 操作符;7.3 及以下必须用
call_user_func_array('array_merge', $arr)
json_encode前要不要用array\_values重索引
要。特别是降维后原数组含非连续数字键或字符串键时,json_encode() 会把结果编码成对象({})而非数组([]),前端 JS 里 Array.isArray() 判定为 false,后续 .map() 或 for...of 就会出问题。
典型场景:数据库查出的关联数组经 array_column($rows, 'name') 提取后直接 json_encode(),返回的是对象而不是预期的 JSON 数组。
立即学习“PHP免费学习笔记(深入)”;
DM建站系统法律律师事务所HTML5网站模板,DM企业建站系统。是由php+mysql开发的一套专门用于中小企业网站建设的开源cms。DM系统的理念就是组装,把模板和区块组装起来,产生不同的网站效果。可以用来快速建设一个响应式的企业网站( PC,手机,微信都可以访问)。后台操作简单,维护方便。DM企业建站系统安装步骤:第一步,先用phpmyadmin导入sql文件。 第二步:把文件放到你的本地服务
- 安全做法:
json_encode(array_values($flat_arr)) - 不推荐:
json_encode($flat_arr, JSON_FORCE_OBJECT)—— 这反而强制输出 {},和需求相反 - 性能影响极小,
array_values()是 C 实现,O(n) 时间且不复制值,只重建键表
遇到 null 或 resource 导致 json_encode失败怎么办
json_encode() 遇到 null 不报错,但遇到 resource、closure、循环引用会返回 false,且 json_last_error_msg() 显示 “Type is not supported”。二维降维时如果原始数据混入了 PDOStatement、文件句柄等,降维后依然存在,encode 就静默失败。
- 降维前清理:
array_walk_recursive($arr, function(&$v) { if (is_resource($v) || is_object($v) && !method_exists($v, '__toString')) $v = null; }) - 更稳妥:用
json_encode($data, JSON_PARTIAL_OUTPUT_ON_ERROR)(PHP 7.3+),把非法值转成 null - 调试技巧:先
var_dump(json_encode($data));看是否为 false,再立刻接echo json_last_error_msg();
laravel 的 Arr::flatten 和原生 array\_merge 有什么区别
Arr::flatten() 默认是“完全展平”,不管几维都压成一维;而 array_merge(...$arr) 只处理一层嵌套。如果你的二维数组里还有子数组(比如 [[1,2], [3,[4,5]]]),Arr::flatten() 会变成 [1,2,3,4,5],原生方法只会得 [1,2,3,[4,5]]。
但注意:Arr::flatten() 会丢弃所有键名,一律重排为数字索引;且不处理 null/resource,仍需自己过滤。
- 只降一层?用
array_merge(...$arr)或call_user_func_array('array_merge', $arr) - 要彻底扁平化且项目已用 Laravel?直接
Arr::flatten($arr, 1)(第二个参数限制深度) - 没 Laravel 又要深度降维?写个简单递归:
function flatten($arr) { return array_reduce($arr, function($r, $a) { return array_merge($r, is_array($a) ? flatten($a) : [$a]); }, []); }
真正容易被忽略的点是:降维和 json_encode 是两个独立环节,中间没做 array_values() 或类型清洗,前端拿到的数据结构就不可靠。别假设“降维完就是标准数组”——PHP 的数组太自由,JSON 却很严格。










