php 父节点,无限级菜单父节点查询所有子节点

写了一个Thinkphp的节点工具,通过传入一个父id查询旗下的子节点。 ThinkPHP ?phpclass Tree{static public $treeList=array();//存放无限极分类结果static public $childNode=array();//存放父节点和父节点下面的子节点//无限级分类排序public function crea

写了一个Thinkphp的节点工具,通过传入一个父id查询旗下的子节点。

ThinkPHP

$value){

if($value['pid']==$pid){

$value['level'] = $level;

self::$treeList[] = $value;

unset($data[$key]);

self::create($data,$value['id'],$level+1);

}

}

return self::$treeList;

}

/******************************************************************************/

/**

* 根据父节点,查询父节点下面的子节点

* @param int $tidtree表ID

*/

public function findChild($tid){

self::$childNode[]=(int)$tid;

$tree=M('Tree');

$map['id']=array('eq',$tid);

$allTree=$tree->field('id,pid')->select();//查询tree表

self::findArrayNode($tid, $allTree);

return self::$childNode;//返回所有节点

}

/**

*

* @param int $id节点ID

* @param array $listtree表所有的id,pid

*/

public function findArrayNode($id,$list){

foreach ($list as $key => $val){

if ($id==$val['pid']){

self::$childNode[]=(int)$val['id'];

self::findArrayNode($val['id'], $list);//递归,传入新节点ID

}

}

}

/******************************************************************************/

//根据findChild()的返回结果,组装sql语句,用于查询news表

public function createSql($arr=array()){

$sql="";

foreach ($arr as $key => $val){

$sql.="tid=$val or ";

}

$sql=trim($sql);//清除空格

$sql=trim($sql,'or');//清除最后的or

$sql=trim($sql);//清除空格

return $sql;

}

/******************************************************************************/

/**

* 根据tid,获取where的sql

* @param int $tid

*/

public function getSql($tid){

return self::createSql(self::findChild($tid));

}

}

/*

用法

import('ORG.Util.Tree');

$list=Tree::create($data);

排序前的数据结构

id   pid

1    0

2    0

3    1

4     3

排序后的数据结构

id  pid  level

1   0    1

3   1   2

4   3    3

2   0   1

*/

?>

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值