概述
写了一个Thinkphp的节点工具,通过传入一个父id查询旗下的子节点。 ThinkPHP ?phpclass Tree{static public $treeList=array();//存放无限极分类结果static public $childNode=array();//存放父节点和父节点下面的子节点//无限级分类排序public function crea
写了一个Thinkphp的节点工具,通过传入一个父id查询旗下的子节点。
ThinkPHP
class Tree{
static public $treeList=array();//存放无限极分类结果
static public $childNode=array();//存放父节点和父节点下面的子节点
//无限级分类排序
public function create($data,$pid = 0,$level = 1){
foreach($data as $key => $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 子菜单所有的父菜单,无限级菜单父节点查询所有子节点的全部内容,希望文章能够帮你解决php 子菜单所有的父菜单,无限级菜单父节点查询所有子节点所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复