无限分类,从数据库查询数据 在数组中递归进行自定义排序
Lepaskan: 2016-07-25 09:02:08
asal
918 orang telah melayarinya
无限分类,从数据库查询数据 在数组中递归进行自定义排序,其中也意识到挺多不足,处理得不好,可能有更好办法,大家一起交流 超过100行了。放不全
- class Tree{
- protected $arr = array(); //排序数组
- protected $info = array(); //存放错误信息
- protected $tree = array(); //存放生成类数组
- protected $flag = true; //标志位
-
- public function __construct()
- {
-
- }
- //得到数据
- public function data($fid,$arr)
- {
- $this->checkArr($arr);
- $this->checking();
- $this->chindAll($fid);
- return $this->tree;
- }
-
- //判断参数是否符合要求
- protected function checkArr($val)
- {
- static $num = 0;
- if(is_array($val)){
- foreach($val as $Varr){
- $this->isKeyVal('id', $Varr, $num);
- $this->isKeyVal('parentid', $Varr, $num);
- $this->isKeyVal('name', $Varr, $num);
- $num++;
- }
- }
- $this->arr = $val;
- }
- //存入id是否是数组
- protected function checkNum($val)
- {
- if(!is_numeric($val)){
- $this->info[] = '传入参数'.$val.'不是数值';
- $this->flag = false;
- $this->checking();
- }
- }
- //验证,输出错误信息
- protected function checking(){
- if(!$this->flag){
- echo '
'; Salin selepas log masuk
- var_dump($this->info);
- exit();
- }
- }
-
- //判断数组键是否存在,是否有值
- protected function isKeyVal($key, $arr, $num)
- {
- if(!array_key_exists($key, $arr))
- {
- $this->info[] = $num.'数组键'.$key.'不存在';
- $this->flag = false;
-
- }
- }
-
- //获得儿子
- public function getChind($fid)
- {
- static $num = 0;
- $arr = array();
- $this->checkNum($fid);
- foreach($this->arr as $key=>$row){
- if( $row['parentid'] == $fid){
- $arr[] = $row;
- unset($this->arr[$key]);
- }
- }
- if(!empty($arr)){
- $num++;
- return $this->sortArr($arr);
- }else{
- return null;
- }
- }
-
- //获取本人儿子孙子
- public function chindAll($fid,$input=null)
- {
- static $n =0;
- $n++;
- $arr = $this->getChind($fid);
- if(!empty($arr)){
- $count = count($arr);
- if(empty($input)){
- for($i=0; $i $this->tree[$i] = $arr[$i];
- }
复制代码
|
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
-
2024-10-22 09:46:29
-
2024-10-13 13:53:41
-
2024-10-12 12:15:51
-
2024-10-11 22:47:31
-
2024-10-11 19:36:51
-
2024-10-11 15:50:41
-
2024-10-11 15:07:41
-
2024-10-11 14:21:21
-
2024-10-11 12:59:11
-
2024-10-11 12:17:31
Topik-topik yang berkaitan
Lagi>