PHP 商城无限极分类

时间:2022-07-12 05:01:28
PHP 商城无限极分类
PHP 商城无限极分类

无限极分类,用的是递归,在外部调用fen()方法即可
                index是刚开始寻找的*分类,suo是为了在前端展示的时候缩进
public function fen($index=,$suo=){         一个数组用来返回的
       $t=[];              这是查询数据库的所有内容
foreach($this->select() as $key=>$value)
{               
if($value["parent_id"]==$p){
      如果说父级ID是刚开始默认的*分类的话,
             就给这个*分类的缩进设置为0
$value["suo"]=$suo;                   然后就是添加这个数组进刚开始定义的数组,下面两种添加方法都可以,我觉得push看的更加明白,
   // $t[]=$value;
array_push($t,$value);                  然后就是递归了,传进去的第一个就是要查找的父级ID,就是当前的这个vlaue的cat_id,找出他下面的子分类,然后都是子分类缩进当然要加一个了.
                 为什么用合并呢,如果用push的话,如果这个分类没有子分类那么会添加进来一个空数组,
                  用合并的话,就会自动屏蔽空数组 $t=array_merge($t,$this->fen($value["cat_id"],$v+)); //array_push($t,$this->fen($value["cat_id"],$v+1));
}
}           最后循环结束,再把查到的递归进来的每个方法中的定义的数组给抛回去
return $t; }

 
我用的是thinkPHP3.2 
我是把递归的方法写在模型里面的,
$this->assign("list",$this->gm->fen());
$this->display("type/catlist");
在Html里面,没有li的左外边距就是缩进的*40就OK,效果就出来了
<foreach name="list" item="item"> <li style="margin-left:{$item[suo]*40}px">
<span class="wl_suo">{$item.v}</span>
{$item.cat_name} <span>上机ID{$item.parent_id}</span></li> </foreach>

但是后台的递归还是不好的方法,好的方法还是把这些数组用json的格式传给前台的js处理,
这样的效率才会高