/**
* 遞歸根據(jù)特定key對數(shù)組排序
* @param $data
* @param string $orderKey
* @param string $sonKey
* @param int $orderBy
* @return mixed
*/
function recursion_orderby($data, $orderKey = 'order', $sonKey = 'children', $orderBy = SORT_ASC)
{
$func = function ($value) use ($sonKey, $orderKey, $orderBy) {
if (isset($value[$sonKey]) is_array($value[$sonKey])) {
$value[$sonKey] = recursion_orderby($value[$sonKey], $orderKey, $sonKey, $orderBy);
}
return $value;
};
return array_orderby(array_map($func, $data), $orderKey, $orderBy);
}
$a = [
[
'order' => 0,
],
[
'order' => -1,
'children' => [
[
'order' => 0,
],
[
'order' => -2,
'children' => [
['order' => 0],
['order' => -1],
['order' => 1],
],
],
],
],
[
'order' => 2,
],
];
var_dump(recursion_orderby($a));
/**
* 輸出:
array(3) {
[0] =>
array(2) {
'order' =>
int(-1)
'children' =>
array(2) {
[0] =>
array(2) {
'order' =>
int(-2)
'children' =>
array(3) {
[0] =>
array(1) {
'order' =>
int(-1)
}
[1] =>
array(1) {
'order' =>
int(0)
}
[2] =>
array(1) {
'order' =>
int(1)
}
}
}
[1] =>
array(1) {
'order' =>
int(0)
}
}
}
[1] =>
array(1) {
'order' =>
int(0)
}
[2] =>
array(1) {
'order' =>
int(2)
}
}
*/
更多關于PHP相關內(nèi)容感興趣的讀者可查看本站專題:《PHP數(shù)據(jù)結(jié)構與算法教程》、《php程序設計算法總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結(jié)》及《PHP數(shù)學運算技巧總結(jié)》