每一个无限分类都需要记录它的父级id,当为顶级分类时,父级id为0.这样无论哪个分类都可以通过父级id一层 层的去查明它所有的父级,以便清楚知道它所属哪种分类,层级深度为多少,无限分类在实际开发中非常常用,无限分类在面试中也会常被问到
include php
/*
使用的是三种递归中的一种 &
/*
include('catecontroller.php');//引入连接数据库文件
function getlist($pid = 0, &$result = array(), $spac = 0)
{
$spac = $spac + 2;//标题前空格重复的次数
$sql = "select * from cate where pid= $pid";//根据父id查找数据
$res = mysql_query($sql);//发送sql语句
while ($row = mysql_fetch_assoc($res)) {//判断$row里的值是否为空然后再循环
$row['cate_name'] = str_repeat(' ',$spac).'|--'.$row['cate_name']; //str_repeat 重复括号里的字符串,后面跟的是次数
$result[] = $row;//把数组赋给 $result
getlist($row['id'],$result,$spac);//递归调用,自己调用自己 这个括号里的参数和上面getlist($pid=0...)是一样的$row['id']==$pid=0;
}
return $result;//把结果返回出去
}
$rs = getlist();//使用方法
var_dump($rs);//打印方法结果
以上无限分类用的是递归算法,递归算法简单的解释就是自己调用自己。
相关推荐:
php无限分类树[支持子分类排序]
php递归遍历多维数组的方法
php递归函数的调用讲解
以上就是php的无限极分类怎么实现?的详细内容。