1. 程式人生 > 程式設計 >Thinkphp框架使用list_to_tree 實現無限級分類列出所有節點示例

Thinkphp框架使用list_to_tree 實現無限級分類列出所有節點示例

本文例項講述了Thinkphp框架使用list_to_tree 實現無限級分類列出所有節點。分享給大家供大家參考,具體如下:

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;
}

更多關於thinkPHP相關內容感興趣的讀者可檢視本站專題:《ThinkPHP入門教程》、《thinkPHP模板操作技巧總結》、《ThinkPHP常用方法總結》、《codeigniter入門教程》、《CI(CodeIgniter)框架進階教程》、《Zend FrameWork框架入門教程》及《PHP模板技術總結》。

希望本文所述對大家基於ThinkPHP框架的PHP程式設計有所幫助。