PHP高效的掏出一切上级:
递归掏出一切上级:
<?php $data = [ [ 'uid' => 1, 'username' => '155', 'parent_username' => '0' ], [ 'uid' => 2, 'username' => '186', 'parent_username' => '155' ], [ 'uid' => 3, 'username' => '189', 'parent_username' => '186' ], [ 'uid' => 4, 'username' => '188', 'parent_username' => '155' ], [ 'uid' => 5, 'username' => '187', 'parent_username' => '188' ], [ 'uid' => 6, 'username' => '1898', 'parent_username' => '146' ], ]; /** * 猎取一切上级 * [getTree description] * @param [type] $data [description] * @param string $parent_username [description] * @return [type] [description] */ //有条理,前往一切上级数据 function getTree($data, $parent_username = '0') { $arr = []; foreach($data as $key => $val){ if($val['parent_username'] == $parent_username){ $val['children'] = getTree($data, $val['username']); $arr[] = $val; } } return $arr; } //无条理,仅前往id function getTree($data, $parent_username = '0', $is_first_time = true) { static $arr = []; if ($is_first_time) { $arr = []; } foreach ($data as $key => $val) { if ($val['parent_username'] == $parent_username) { $arr[] = $val['uid']; getTree($data, $val['username'], false); } } return $arr; } echo '<pre>'; print_r(getTree($data)); ?>
保举:php效劳器
以上就是php若何高效找出一切上级的具体内容,更多请存眷资源魔其它相干文章!
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
抱歉,评论功能暂时关闭!