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目录管理函数小结
Sep 10 PHP
php下清空字符串中的HTML标签的代码
Sep 06 PHP
php array_unique之后json_encode需要注意
Jan 02 PHP
PHP的几个常用数字判断函数代码
Apr 24 PHP
php读取excel文件的简单实例
Aug 26 PHP
php分页代码学习示例分享
Feb 20 PHP
PHP中soap的用法实例
Oct 24 PHP
php采集中国代理服务器网的方法
Jun 16 PHP
php通过文件头判断格式的方法
May 28 PHP
PHP中常见的密码处理方式和建议总结
Oct 14 PHP
Thinkphp5.0 框架Model模型简单用法分析
Oct 11 PHP
关于PHP5.6+版本“No input file specified”问题的解决
Dec 11 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
php中sql注入漏洞示例 sql注入漏洞修复
2014/01/24 PHP
php中base_convert()进制数字转换函数实例
2014/11/20 PHP
使用PHP+AJAX让WordPress动态加载文章的教程
2015/12/11 PHP
thinkphp3.2实现在线留言提交验证码功能
2017/07/19 PHP
Yii 实现数据加密和解密
2021/03/09 PHP
用JavaScript和注册表脚本实现右键收藏Web页选中文本
2007/01/28 Javascript
限制textbox或textarea输入字符长度的JS代码
2013/10/16 Javascript
javascript的事件触发器介绍的实现
2014/06/05 Javascript
后台获取ZTREE选中节点的方法
2015/02/12 Javascript
js类式继承与原型式继承详解
2016/04/07 Javascript
JS实现滑动门效果的方法详解
2016/12/19 Javascript
jquery滚动条插件slimScroll使用方法
2017/02/09 Javascript
JavaScript实现256色转灰度图
2017/02/22 Javascript
简单实现jquery隔行变色
2017/11/09 jQuery
Vue项目中添加锁屏功能实现思路
2018/06/29 Javascript
jQuery判断自定义属性data-val用法示例
2019/01/07 jQuery
在Create React App中使用CSS Modules的方法示例
2019/01/15 Javascript
微信小程序12行js代码自己写个滑块功能(推荐)
2020/07/15 Javascript
小程序组件传值和引入sass的方法(使用vant Weapp组件库)
2020/11/24 Javascript
[01:46]DOTA2上海特锦赛小组赛英文解说KotlGuy采访
2016/02/27 DOTA
[07:20]2018DOTA2国际邀请赛寻真——逐梦Mineski
2018/08/10 DOTA
[04:32]玩具屠夫中文语音节选
2020/08/23 DOTA
Python中的文件和目录操作实现代码
2011/03/13 Python
使用Python判断IP地址合法性的方法实例
2014/03/13 Python
Python中处理unchecked未捕获异常实例
2015/01/17 Python
python根据时间生成mongodb的ObjectId的方法
2015/03/13 Python
用ReactJS和Python的Flask框架编写留言板的代码示例
2015/12/19 Python
python读取文件名并改名字的实例
2019/01/07 Python
python画图把时间作为横坐标的方法
2019/07/07 Python
全球500多个机场的接送服务:Suntransfers
2019/06/03 全球购物
多媒体编辑专业毕业生推荐信
2013/11/05 职场文书
2014社区三八妇女节活动方案
2014/03/30 职场文书
投资建议书模板
2014/05/12 职场文书
精神病医院见习报告
2014/11/03 职场文书
严以修身专题学习研讨会发言材料
2015/11/09 职场文书
《唯一的听众》教学反思
2016/02/18 职场文书