thinkphp无限递归查询分类

时间:2021-08-26 00:25:37
 // 遍历父id下所有数据
        function getson($parent_id = 0, $t = - 1) {
            $t++;
            global $temp;
            $data = M('youerdbname')->where('fatherid=' . $parent_id)->select();
            if (!empty($data)) {
                foreach ($data as $key => $val) {
                    $temp[] = $data;
                    getson($val['id'], $t);
                }
            }
            return $temp;
        }
        if ($_SESSION['uid'] != 1) {
            $massage = getson($_SESSION['uid']);

        }

无限递归查询分类工作理解

thinkphp无限递归查询分类

1.首先我们来看一下foreach循环是什么意思,如果你懂foreach就可以跳过此步了。

开始的时候我也不理解foreach循环遍历数组是什么东西,废话少说,我们进入主题。

我们先看一下,下面这个一维数组,一维数组就不用说了吧

$a = array('','','','','','','','','','');

thinkphp无限递归查询分类

//看一下三种输出,你应该明白了,foreach遍历数组应该是干什么了吧!其实也就是把数组中的值给弄出来而已,当然你也可以用echo一个一个的给输出出来,只要你有劲,foreach就简单几句话搞定。

thinkphp无限递归查询分类


 


看完foreach我们真正进入主题,看一下无限递归到底是怎样工作的。

function getsort($table,$parent_id=0,$t=-1)

{

$t++;

global $temp;

$sql = "SELECT * FROM `$table` WHERE `parent_id`=$parent_id ORDER BY `sort_id`";

$query = mysql_query($sql);

$data = array();

while ($res = mysql_fetch_assoc($query))//循环出父级分类

{

$data[] = $res;

}

if(!empty($data))

  {

foreach ($data as $key => $val )

{

$val['sort_name'] = str_repeat(' ',$t*3).'|--'.$val['sort_name'];

$temp[] = $val;

getsort($table,$val['sort_id'],$t);

}

}

return $temp;

}

看上面的while循环,当while循环完成以后,告诉我$data这个二维数组里面存的是什么?当然是一个二维数组了,而且是parent_id=0的所有数据,也就是第一级分类了。如下图:

thinkphp无限递归查询分类


 再来看看下面这一段程序

if(!empty($data))//如果$date里面不为空,即里面有数据,就会执行下面的foreach循环

{

foreach ($data as $key => $val )

{

$val['sort_name'] = str_repeat(' ',$t*3).'|--'.$val['sort_name'];

$temp[] = $val; //把变形的sort_name在注入一个数组里

getsort($table,$val['sort_id'],$t);

}

}

首先$data不为空吧,那么foreach循环就会执行了,

foreach首先取出一条数据即$data[0],注意看上图也就是sort_id=1的所有数据

sort_id=1的这条数据里的sort_name值给变化一下,方便做出阶梯效果的分类。

把变形的sort_name在注入一个数组里。

然后调用自己getsort,关键就在这个地方,好多人刚开始不理解,我刚开始也很不理解

关键就在下面接下来做什么?看它是怎么调用自己的,注意它调用自己时,传过去的id$val[‘sort_id’];也就是说,下一次要查询的是parent_id=1的所有数据是吧?

最绕人的地方就是下面的解释:

4部调用自己,去查询sort_id=1的所有子分类,和上面一样的循环过程。foreach首先取出的是第一条数据,后面是不是还有4条数据没有循环。当sort_id=1下面的所有分类查询完以后,接着 取出第二条数据,也就是$data[1],注意看上图也就是sort_id=2的所有数据,接着就是重复上面的动作。

还有一种比较好的理解方法,当它调用自己时即getsort($table,$val['sort_id'],$t);把这句话替换成getsort()函数它本身,就容易理解多了。

可能我解释的还不够清楚,不知到你是否理解了。


调用一下这个函数,然后循环一下就是下图这个样子

$a = getsort('article_sort');

foreach ($a as $key => $val )

{

echo '<pre>';

echo $val['sort_name'];

}

thinkphp无限递归查询分类