主頁(yè) > 知識(shí)庫(kù) > PHP樹(shù)形結(jié)構(gòu)tree類(lèi)用法示例

PHP樹(shù)形結(jié)構(gòu)tree類(lèi)用法示例

熱門(mén)標(biāo)簽:打開(kāi)百度地圖標(biāo)注 400 電話 辦理 蘇州外呼系統(tǒng)有效果嗎 智能電銷(xiāo)語(yǔ)音機(jī)器人資訊 亳州企業(yè)外呼系統(tǒng) 海南外呼系統(tǒng)方案 兼職做地圖標(biāo)注好賺錢(qián)嗎 地圖標(biāo)注怎么做商戶(hù)驗(yàn)證 山東電銷(xiāo)卡外呼系統(tǒng)原理是什么

本文實(shí)例講述了PHP樹(shù)形結(jié)構(gòu)tree類(lèi)用法。分享給大家供大家參考,具體如下:

?php
include 'tree.class.php';
//模擬數(shù)據(jù)庫(kù)
$data=array(
  array('id'=>1,'pid'=>0,'name'=>'一級(jí)欄目一'),
  array('id'=>2,'pid'=>0,'name'=>'一級(jí)欄目二'),
  array('id'=>3,'pid'=>1,'name'=>'二級(jí)欄目一'),
  array('id'=>4,'pid'=>3,'name'=>'三級(jí)欄目一'),
  array('id'=>5,'pid'=>4,'name'=>'四級(jí)欄目一'),
);
//轉(zhuǎn)換數(shù)據(jù)
$tree_data=array();
foreach ($data as $key=>$value){
  $tree_data[$value['id']]=array(
    'id'=>$value['id'],
    'parentid'=>$value['pid'],
    'name'=>$value['name']
  );
}
/**
 * 輸出樹(shù)形結(jié)構(gòu)
 */
$str="tr>
  td>input type='checkbox' name='list[\$id]' value='\$id'>/td>
  td>\$id/td>
  td>\$spacer\$name/td>
  td>a href='add.php?id=\$id'>添加/a>/td>
  td>a href='del.php?id=\$id'>刪除/a>/td>
  td>a href='update.php?id='\$id'>修改/a>/td>
  /tr>";
$tree=new Tree();
$tree->init($tree_data);
echo "table>";
echo $tree->get_tree(0, $str);
echo "/table>";
echo "br/>";
echo "br/>";
echo "br/>";
echo "br/>";
/**
 * 輸出下拉列表
 */
$str="option value=\$id \$selected>\$spacer\$name/option>";
$tree=new Tree();
$tree->init($tree_data);
echo "select>";
echo $tree->get_tree(0, $str,2);
echo "/select>";

運(yùn)行結(jié)果:

tree.class.php:

?php
/**
* 通用的樹(shù)型類(lèi),可以生成任何樹(shù)型結(jié)構(gòu)
*/
class tree {
  /**
  * 生成樹(shù)型結(jié)構(gòu)所需要的2維數(shù)組
  * @var array
  */
  public $arr = array();
  /**
  * 生成樹(shù)型結(jié)構(gòu)所需修飾符號(hào),可以換成圖片
  * @var array
  */
  public $icon = array('│','├','└');
  public $nbsp = " ";
  /**
  * @access private
  */
  public $ret = '';
  /**
  * 構(gòu)造函數(shù),初始化類(lèi)
  * @param array 2維數(shù)組,例如:
  * array(
  *   1 => array('id'=>'1','parentid'=>0,'name'=>'一級(jí)欄目一'),
  *   2 => array('id'=>'2','parentid'=>0,'name'=>'一級(jí)欄目二'),
  *   3 => array('id'=>'3','parentid'=>1,'name'=>'二級(jí)欄目一'),
  *   4 => array('id'=>'4','parentid'=>1,'name'=>'二級(jí)欄目二'),
  *   5 => array('id'=>'5','parentid'=>2,'name'=>'二級(jí)欄目三'),
  *   6 => array('id'=>'6','parentid'=>3,'name'=>'三級(jí)欄目一'),
  *   7 => array('id'=>'7','parentid'=>3,'name'=>'三級(jí)欄目二')
  *   )
  */
  public function init($arr=array()){
    $this->arr = $arr;
    $this->ret = '';
    return is_array($arr);
  }
  /**
  * 得到父級(jí)數(shù)組
  * @param int
  * @return array
  */
  public function get_parent($myid){
    $newarr = array();
    if(!isset($this->arr[$myid])) return false;
    $pid = $this->arr[$myid]['parentid'];
    $pid = $this->arr[$pid]['parentid'];
    if(is_array($this->arr)){
      foreach($this->arr as $id => $a){
        if($a['parentid'] == $pid) $newarr[$id] = $a;
      }
    }
    return $newarr;
  }
  /**
  * 得到子級(jí)數(shù)組
  * @param int
  * @return array
  */
  public function get_child($myid){
    $a = $newarr = array();
    if(is_array($this->arr)){
      foreach($this->arr as $id => $a){
        if($a['parentid'] == $myid) $newarr[$id] = $a;
      }
    }
    return $newarr ? $newarr : false;
  }
  /**
  * 得到當(dāng)前位置數(shù)組
  * @param int
  * @return array
  */
  public function get_pos($myid,$newarr){
    $a = array();
    if(!isset($this->arr[$myid])) return false;
    $newarr[] = $this->arr[$myid];
    $pid = $this->arr[$myid]['parentid'];
    if(isset($this->arr[$pid])){
      $this->get_pos($pid,$newarr);
    }
    if(is_array($newarr)){
      krsort($newarr);
      foreach($newarr as $v){
        $a[$v['id']] = $v;
      }
    }
    return $a;
  }
  /**
  * 得到樹(shù)型結(jié)構(gòu)
  * @param int ID,表示獲得這個(gè)ID下的所有子級(jí)
  * @param string 生成樹(shù)型結(jié)構(gòu)的基本代碼,例如:"option value=\$id \$selected>\$spacer\$name/option>"
  * @param int 被選中的ID,比如在做樹(shù)型下拉框的時(shí)候需要用到
  * @return string
  */
  public function get_tree($myid, $str, $sid = 0, $adds = '', $str_group = ''){
    $number=1;
    $child = $this->get_child($myid);
    if(is_array($child)){
      $total = count($child);
      foreach($child as $id=>$value){
        $j=$k='';
        if($number==$total){
          $j .= $this->icon[2];
        }else{
          $j .= $this->icon[1];
          $k = $adds ? $this->icon[0] : '';
        }
        $spacer = $adds ? $adds.$j : '';
        $selected = $id==$sid ? 'selected' : '';
        @extract($value);
        $parentid == 0  $str_group ? eval("\$nstr = \"$str_group\";") : eval("\$nstr = \"$str\";");
        $this->ret .= $nstr;
        $nbsp = $this->nbsp;
        $this->get_tree($id, $str, $sid, $adds.$k.$nbsp,$str_group);
        $number++;
      }
    }
    return $this->ret;
  }
  /**
  * 同上一方法類(lèi)似,但允許多選
  */
  public function get_tree_multi($myid, $str, $sid = 0, $adds = ''){
    $number=1;
    $child = $this->get_child($myid);
    if(is_array($child)){
      $total = count($child);
      foreach($child as $id=>$a){
        $j=$k='';
        if($number==$total){
          $j .= $this->icon[2];
        }else{
          $j .= $this->icon[1];
          $k = $adds ? $this->icon[0] : '';
        }
        $spacer = $adds ? $adds.$j : '';
        $selected = $this->have($sid,$id) ? 'selected' : '';
        @extract($a);
        eval("\$nstr = \"$str\";");
        $this->ret .= $nstr;
        $this->get_tree_multi($id, $str, $sid, $adds.$k.' ');
        $number++;
      }
    }
    return $this->ret;
  }
   /**
  * @param integer $myid 要查詢(xún)的ID
  * @param string $str  第一種HTML代碼方式
  * @param string $str2 第二種HTML代碼方式
  * @param integer $sid 默認(rèn)選中
  * @param integer $adds 前綴
  */
  public function get_tree_category($myid, $str, $str2, $sid = 0, $adds = ''){
    $number=1;
    $child = $this->get_child($myid);
    if(is_array($child)){
      $total = count($child);
      foreach($child as $id=>$a){
        $j=$k='';
        if($number==$total){
          $j .= $this->icon[2];
        }else{
          $j .= $this->icon[1];
          $k = $adds ? $this->icon[0] : '';
        }
        $spacer = $adds ? $adds.$j : '';
        $selected = $this->have($sid,$id) ? 'selected' : '';
        @extract($a);
        if (empty($html_disabled)) {
          eval("\$nstr = \"$str\";");
        } else {
          eval("\$nstr = \"$str2\";");
        }
        $this->ret .= $nstr;
        $this->get_tree_category($id, $str, $str2, $sid, $adds.$k.' ');
        $number++;
      }
    }
    return $this->ret;
  }
  /**
   * 同上一類(lèi)方法,jquery treeview 風(fēng)格,可伸縮樣式(需要treeview插件支持)
   * @param $myid 表示獲得這個(gè)ID下的所有子級(jí)
   * @param $effected_id 需要生成treeview目錄數(shù)的id
   * @param $str 末級(jí)樣式
   * @param $str2 目錄級(jí)別樣式
   * @param $showlevel 直接顯示層級(jí)數(shù),其余為異步顯示,0為全部限制
   * @param $style 目錄樣式 默認(rèn) filetree 可增加其他樣式如'filetree treeview-famfamfam'
   * @param $currentlevel 計(jì)算當(dāng)前層級(jí),遞歸使用 適用改函數(shù)時(shí)不需要用該參數(shù)
   * @param $recursion 遞歸使用 外部調(diào)用時(shí)為FALSE
   */
  function get_treeview($myid,$effected_id='example',$str="span class='file'>\$name/span>", $str2="span class='folder'>\$name/span>" ,$showlevel = 0 ,$style='filetree ' , $currentlevel = 1,$recursion=FALSE) {
    $child = $this->get_child($myid);
    if(!defined('EFFECTED_INIT')){
      $effected = ' id="'.$effected_id.'"';
      define('EFFECTED_INIT', 1);
    } else {
      $effected = '';
    }
    $placeholder =   'ul>li>span class="placeholder">/span>/li>/ul>';
    if(!$recursion) $this->str .='ul'.$effected.' class="'.$style.'">';
    foreach($child as $id=>$a) {
      @extract($a);
      if($showlevel > 0  $showlevel == $currentlevel  $this->get_child($id)) $folder = 'hasChildren'; //如設(shè)置顯示層級(jí)模式@2011.07.01
      $floder_status = isset($folder) ? ' class="'.$folder.'"' : '';
      $this->str .= $recursion ? 'ul>li'.$floder_status.' id=\''.$id.''>' : 'li'.$floder_status.' id=\''.$id.''>';
      $recursion = FALSE;
      if($this->get_child($id)){
        eval("\$nstr = \"$str2\";");
        $this->str .= $nstr;
        if($showlevel == 0 || ($showlevel > 0  $showlevel > $currentlevel)) {
          $this->get_treeview($id, $effected_id, $str, $str2, $showlevel, $style, $currentlevel+1, TRUE);
        } elseif($showlevel > 0  $showlevel == $currentlevel) {
          $this->str .= $placeholder;
        }
      } else {
        eval("\$nstr = \"$str\";");
        $this->str .= $nstr;
      }
      $this->str .=$recursion ? '/li>/ul>': '/li>';
    }
    if(!$recursion) $this->str .='/ul>';
    return $this->str;
  }
  /**
   * 獲取子欄目json
   * Enter description here ...
   * @param unknown_type $myid
   */
  public function creat_sub_json($myid, $str='') {
    $sub_cats = $this->get_child($myid);
    $n = 0;
    if(is_array($sub_cats)) foreach($sub_cats as $c) {
      $data[$n]['id'] = iconv(CHARSET,'utf-8',$c['catid']);
      if($this->get_child($c['catid'])) {
        $data[$n]['liclass'] = 'hasChildren';
        $data[$n]['children'] = array(array('text'=>' ','classes'=>'placeholder'));
        $data[$n]['classes'] = 'folder';
        $data[$n]['text'] = iconv(CHARSET,'utf-8',$c['catname']);
      } else {
        if($str) {
          @extract(array_iconv($c,CHARSET,'utf-8'));
          eval("\$data[$n]['text'] = \"$str\";");
        } else {
          $data[$n]['text'] = iconv(CHARSET,'utf-8',$c['catname']);
        }
      }
      $n++;
    }
    return json_encode($data);
  }
  private function have($list,$item){
    return(strpos(',,'.$list.',',','.$item.','));
  }
}
?>

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》、《PHP常用遍歷算法與技巧總結(jié)》、《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • php實(shí)現(xiàn)的樹(shù)形結(jié)構(gòu)數(shù)據(jù)存取類(lèi)實(shí)例
  • thinkPHP實(shí)現(xiàn)遞歸循環(huán)欄目并按照樹(shù)形結(jié)構(gòu)無(wú)限極輸出的方法
  • PHP無(wú)限分類(lèi)(樹(shù)形類(lèi))
  • 基于遞歸實(shí)現(xiàn)的php樹(shù)形菜單代碼
  • php從數(shù)據(jù)庫(kù)查詢(xún)結(jié)果生成樹(shù)形列表的方法
  • PHP無(wú)限分類(lèi)(樹(shù)形類(lèi))的深入分析
  • php簡(jiǎn)單實(shí)現(xiàn)無(wú)限分類(lèi)樹(shù)形列表的方法
  • php顯示當(dāng)前文件所在的文件以及文件夾所有文件以樹(shù)形展開(kāi)
  • php 無(wú)限分類(lèi) 樹(shù)形數(shù)據(jù)格式化代碼

標(biāo)簽:萊蕪 綏化 清遠(yuǎn) 溫州 紹興 呼倫貝爾 金華 安康

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP樹(shù)形結(jié)構(gòu)tree類(lèi)用法示例》,本文關(guān)鍵詞  PHP,樹(shù)形,結(jié)構(gòu),tree,類(lèi),用法,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP樹(shù)形結(jié)構(gòu)tree類(lèi)用法示例》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于PHP樹(shù)形結(jié)構(gòu)tree類(lèi)用法示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章