关于 list_to_tree 实现无限级分类列出所有节点 的问题

浏览:4172 发布日期:2015/07/18 分类:求助交流 关键字: list_to_tree,无限级分类
网上找着了这个例子public function index(){
  Load('extend');            //加载扩展方法
  $Category=D('Category');
  $list=$Category->order('sort desc')->select();//实现同级节点排序
  $list=list_to_tree($list,'id','fid'); //详细参数见手册
  $list=$this->findChild($list);    
  dump($list);
}
protected  function findChild($arr){
    static $tree=array();
    foreach ($arr as $key=>$val){
        $tree[]=$val;
        if (isset($val['_child'])){
          $this->findChild($val['_child']);
        }        
      }
  return $tree;
}
还有一段/**
 * 把返回的数据集转换成Tree
 * @access public
 * @param array $list 要转换的数据集
 * @param string $pid parent标记字段
 * @param string $level level标记字段
 * @return array
 */
function list_to_tree($list, $pk='id',$pid = 'pid',$child = '_child',$root=0) {
  // 创建Tree
  $tree = array();
  if(is_array($list)) {
    // 创建基于主键的数组引用
    $refer = array();
    foreach ($list as $key => $data) {
      $refer[$data[$pk]] =& $list[$key];
    }
    foreach ($list as $key => $data) {
      // 判断是否存在parent
      $parentId = $data[$pid];
      if ($root == $parentId) {
        $tree[] =& $list[$key];
      }else{
        if (isset($refer[$parentId])) {
          $parent =& $refer[$parentId];
          $parent[$child][] =& $list[$key];
        }
      }
    }
  }
  return $tree;
}

/**
 * 对查询结果集进行排序
 * @access public
 * @param array $list 查询结果
 * @param string $field 排序的字段名
 * @param array $sortby 排序类型
 * asc正向排序 desc逆向排序 nat自然排序
 * @return array
 */
function list_sort_by($list,$field, $sortby='asc') {
   if(is_array($list)){
     $refer = $resultSet = array();
     foreach ($list as $i => $data)
       $refer[$i] = &$data[$field];
     switch ($sortby) {
       case 'asc': // 正向排序
        asort($refer);
        break;
       case 'desc':// 逆向排序
        arsort($refer);
        break;
       case 'nat': // 自然排序
        natcasesort($refer);
        break;
     }
     foreach ( $refer as $key=> $val)
       $resultSet[] = &$list[$key];
     return $resultSet;
   }
   return false;
}

/**
 * 在数据列表中搜索
 * @access public
 * @param array $list 数据列表
 * @param mixed $condition 查询条件
 * 支持 array('name'=>$value) 或者 name=$value
 * @return array
 */
function list_search($list,$condition) {
  if(is_string($condition))
    parse_str($condition,$condition);
  // 返回的结果集合
  $resultSet = array();
  foreach ($list as $key=>$data){
    $find   =   false;
    foreach ($condition as $field=>$value){
      if(isset($data[$field])) {
        if(0 === strpos($value,'/')) {
          $find   =   preg_match($value,$data[$field]);
        }elseif($data[$field]==$value){
          $find = true;
        }
      }
    }
    if($find)
      $resultSet[]     =   &$list[$key];
  }
  return $resultSet;
}
我把上边都放在了我的控制器文件里
因为,我的栏目表用的是字段order名进行排序的,父级字段是fatherid
子类字段是ChildID
所以变成这样<?php
namespace ADMIN\Controller;
use Think\Controller; 
class ChannelController extends Controller {
    //常用语句 select() select(30) select("1,23,78") 返回二维 find(20)返回一维
    //查询函数 count()  sum()   avg()   max()   min()
    //列出信息 limit(10,5) 从第11条开始 调用5条信息 
    function index(){
      $qtable = M('Channel') -> order(array('order','id'=>'desc')) ->select();//实现同级节点排序 
      show_bug($qtable);
      $qtable=list_to_tree($qtable,'ID','FatherID'); //详细参数见手册
      $qtable=$this->findChild($qtable);    
      dump($qtable);
    }
    protected  function findChild($arr){
        static $tree=array();
        foreach ($arr as $key=>$val){
            $tree[]=$val;
            if (isset($val['_child'])){
              $this->findChild($val['_child']);
            }        
          }
      return $tree;
    }
 

 
    
    /**
 * 把返回的数据集转换成Tree
 * @access public
 * @param array $list 要转换的数据集
 * @param string $pid parent标记字段
 * @param string $level level标记字段
 * @return array
 */
function list_to_tree($list, $pk='id',$pid = 'pid',$child = '_child',$root=0) {
  // 创建Tree
  $tree = array();
  if(is_array($list)) {
    // 创建基于主键的数组引用
    $refer = array();
    foreach ($list as $key => $data) {
      $refer[$data[$pk]] =& $list[$key];
    }
    foreach ($list as $key => $data) {
      // 判断是否存在parent
      $parentId = $data[$pid];
      if ($root == $parentId) {
        $tree[] =& $list[$key];
      }else{
        if (isset($refer[$parentId])) {
          $parent =& $refer[$parentId];
          $parent[$child][] =& $list[$key];
        }
      }
    }
  }
  return $tree;
}

/**
 * 对查询结果集进行排序
 * @access public
 * @param array $list 查询结果
 * @param string $field 排序的字段名
 * @param array $sortby 排序类型
 * asc正向排序 desc逆向排序 nat自然排序
 * @return array
 */
function list_sort_by($list,$field, $sortby='asc') {
   if(is_array($list)){
     $refer = $resultSet = array();
     foreach ($list as $i => $data)
       $refer[$i] = &$data[$field];
     switch ($sortby) {
       case 'asc': // 正向排序
        asort($refer);
        break;
       case 'desc':// 逆向排序
        arsort($refer);
        break;
       case 'nat': // 自然排序
        natcasesort($refer);
        break;
     }
     foreach ( $refer as $key=> $val)
       $resultSet[] = &$list[$key];
     return $resultSet;
   }
   return false;
}

/**
 * 在数据列表中搜索
 * @access public
 * @param array $list 数据列表
 * @param mixed $condition 查询条件
 * 支持 array('name'=>$value) 或者 name=$value
 * @return array
 */
function list_search($list,$condition) {
  if(is_string($condition))
    parse_str($condition,$condition);
  // 返回的结果集合
  $resultSet = array();
  foreach ($list as $key=>$data){
    $find   =   false;
    foreach ($condition as $field=>$value){
      if(isset($data[$field])) {
        if(0 === strpos($value,'/')) {
          $find   =   preg_match($value,$data[$field]);
        }elseif($data[$field]==$value){
          $find = true;
        }
      }
    }
    if($find)
      $resultSet[]     =   &$list[$key];
  }
  return $resultSet;
}
}
但提示出错了,求大神帮看看错在哪儿
不胜感激!
最佳答案
评论( 相关
后面还有条评论,点击查看>>