PHP树形结构tree类用法示例


Posted in PHP onFebruary 01, 2019

本文实例讲述了PHP树形结构tree类用法。分享给大家供大家参考,具体如下:

<?php
include 'tree.class.php';
//模拟数据库
$data=array(
  array('id'=>1,'pid'=>0,'name'=>'一级栏目一'),
  array('id'=>2,'pid'=>0,'name'=>'一级栏目二'),
  array('id'=>3,'pid'=>1,'name'=>'二级栏目一'),
  array('id'=>4,'pid'=>3,'name'=>'三级栏目一'),
  array('id'=>5,'pid'=>4,'name'=>'四级栏目一'),
);
//转换数据
$tree_data=array();
foreach ($data as $key=>$value){
  $tree_data[$value['id']]=array(
    'id'=>$value['id'],
    'parentid'=>$value['pid'],
    'name'=>$value['name']
  );
}
/**
 * 输出树形结构
 */
$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>";

运行结果:

PHP树形结构tree类用法示例

tree.class.php:

<?php
/**
* 通用的树型类,可以生成任何树型结构
*/
class tree {
  /**
  * 生成树型结构所需要的2维数组
  * @var array
  */
  public $arr = array();
  /**
  * 生成树型结构所需修饰符号,可以换成图片
  * @var array
  */
  public $icon = array('│','├','└');
  public $nbsp = " ";
  /**
  * @access private
  */
  public $ret = '';
  /**
  * 构造函数,初始化类
  * @param array 2维数组,例如:
  * array(
  *   1 => array('id'=>'1','parentid'=>0,'name'=>'一级栏目一'),
  *   2 => array('id'=>'2','parentid'=>0,'name'=>'一级栏目二'),
  *   3 => array('id'=>'3','parentid'=>1,'name'=>'二级栏目一'),
  *   4 => array('id'=>'4','parentid'=>1,'name'=>'二级栏目二'),
  *   5 => array('id'=>'5','parentid'=>2,'name'=>'二级栏目三'),
  *   6 => array('id'=>'6','parentid'=>3,'name'=>'三级栏目一'),
  *   7 => array('id'=>'7','parentid'=>3,'name'=>'三级栏目二')
  *   )
  */
  public function init($arr=array()){
    $this->arr = $arr;
    $this->ret = '';
    return is_array($arr);
  }
  /**
  * 得到父级数组
  * @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;
  }
  /**
  * 得到子级数组
  * @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;
  }
  /**
  * 得到当前位置数组
  * @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;
  }
  /**
  * 得到树型结构
  * @param int ID,表示获得这个ID下的所有子级
  * @param string 生成树型结构的基本代码,例如:"<option value=\$id \$selected>\$spacer\$name</option>"
  * @param int 被选中的ID,比如在做树型下拉框的时候需要用到
  * @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;
  }
  /**
  * 同上一方法类似,但允许多选
  */
  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 要查询的ID
  * @param string $str  第一种HTML代码方式
  * @param string $str2 第二种HTML代码方式
  * @param integer $sid 默认选中
  * @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;
  }
  /**
   * 同上一类方法,jquery treeview 风格,可伸缩样式(需要treeview插件支持)
   * @param $myid 表示获得这个ID下的所有子级
   * @param $effected_id 需要生成treeview目录数的id
   * @param $str 末级样式
   * @param $str2 目录级别样式
   * @param $showlevel 直接显示层级数,其余为异步显示,0为全部限制
   * @param $style 目录样式 默认 filetree 可增加其他样式如'filetree treeview-famfamfam'
   * @param $currentlevel 计算当前层级,递归使用 适用改函数时不需要用该参数
   * @param $recursion 递归使用 外部调用时为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'; //如设置显示层级模式@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.','));
  }
}
?>

希望本文所述对大家PHP程序设计有所帮助。

PHP 相关文章推荐
php a simple smtp class
Nov 26 PHP
flash用php连接数据库的代码
Apr 21 PHP
php循环语句 for()与foreach()用法区别介绍
Sep 05 PHP
修改apache配置文件去除thinkphp url中的index.php
Jan 17 PHP
PHP实现QQ登录实例代码
Jan 14 PHP
php使用get_class_methods()函数获取分类的方法
Jul 20 PHP
php  单例模式详细介绍及实现源码
Nov 05 PHP
PHP屏蔽关键字实现方法
Nov 17 PHP
php json相关函数用法示例
Mar 28 PHP
Laravel框架实现多个视图共享相同数据的方法详解
Jul 09 PHP
TP3.2.3框架使用CKeditor编辑器在页面中上传图片的方法分析
Dec 31 PHP
php使用redis的几种常见操作方式和用法示例
Feb 20 PHP
PHP-FPM和Nginx的通信机制详解
Feb 01 #PHP
Laravel框架自定义验证过程实例分析
Feb 01 #PHP
thinkPHP框架RBAC实现原理分析
Feb 01 #PHP
PHP PDOStatement::fetchColumn讲解
Jan 31 #PHP
PHP PDOStatement::fetchAll讲解
Jan 31 #PHP
PHP PDOStatement::fetch讲解
Jan 31 #PHP
PHP PDOStatement::execute讲解
Jan 31 #PHP
You might like
对javascript和select部件的结合运用
2006/10/09 PHP
PHP实现绘制3D扇形统计图及图片缩放实例
2014/10/01 PHP
php将12小时制转换成24小时制的方法
2015/03/31 PHP
php中类和对象:静态属性、静态方法
2017/04/09 PHP
jquery js 获取时间差、时间格式具体代码
2013/06/05 Javascript
JavaScript基础篇之变量作用域、传值、传址的简单介绍与实例
2013/06/29 Javascript
JQuery打造省市下拉框联动效果
2014/05/18 Javascript
Nodejs进程管理模块forever详解
2014/06/01 NodeJs
JavaScript的History API使搜索引擎抓取AJAX内容
2015/12/07 Javascript
NodeJS创建基础应用并应用模板引擎
2016/04/12 NodeJs
js中的触发事件对象event.srcElement与event.target详解
2017/03/15 Javascript
微信小程序对接七牛云存储的方法
2017/07/30 Javascript
详解用webpack的CommonsChunkPlugin提取公共代码的3种方式
2017/11/09 Javascript
jQuery中使用validate插件校验表单功能
2019/05/24 jQuery
浅谈v-for 和 v-if 并用时筛选条件方法
2019/11/07 Javascript
vue实现简单学生信息管理
2020/05/30 Javascript
jQuery实现简单全选框
2020/09/13 jQuery
[48:02]Ti4循环赛第三日 VG vs Liquid和NEWBEE vs DK
2014/07/12 DOTA
用Python脚本来删除指定容量以上的文件的教程
2015/05/04 Python
Python中字典映射类型的学习教程
2015/08/20 Python
详解Django+Uwsgi+Nginx的生产环境部署
2018/06/25 Python
浅谈Pandas:Series和DataFrame间的算术元素
2018/12/22 Python
python使用tkinter库实现五子棋游戏
2019/06/18 Python
解决Djang2.0.1中的reverse导入失败的问题
2019/08/16 Python
PyCharm无法引用自身项目解决方式
2020/02/12 Python
Python动态导入模块:__import__、importlib、动态导入的使用场景实例分析
2020/03/30 Python
Tensorflow tf.nn.depthwise_conv2d如何实现深度卷积的
2020/04/20 Python
python 利用zmail库发送邮件
2020/09/11 Python
CSS3中Transition动画属性用法详解
2016/07/04 HTML / CSS
教师评优的个人自我评价分享
2013/09/19 职场文书
软件毕业生个人鉴定
2014/03/03 职场文书
不拖欠农民工工资承诺书
2014/03/31 职场文书
兵马俑导游词
2015/02/02 职场文书
小班下学期个人总结
2015/02/12 职场文书
初中班主任工作随笔
2015/08/15 职场文书
浅谈JS和Nodejs中的事件驱动
2021/05/05 NodeJs